真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

C++怎么實(shí)現(xiàn)翻轉(zhuǎn)整數(shù)-創(chuàng)新互聯(lián)

這篇文章主要介紹“C++怎么實(shí)現(xiàn)翻轉(zhuǎn)整數(shù)”,在日常操作中,相信很多人在C++怎么實(shí)現(xiàn)翻轉(zhuǎn)整數(shù)問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C++怎么實(shí)現(xiàn)翻轉(zhuǎn)整數(shù)”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

創(chuàng)新互聯(lián)專注于白云鄂網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供白云鄂營銷型網(wǎng)站建設(shè),白云鄂網(wǎng)站制作、白云鄂網(wǎng)頁設(shè)計(jì)、白云鄂網(wǎng)站官網(wǎng)定制、小程序定制開發(fā)服務(wù),打造白云鄂網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供白云鄂網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

Reverse Integer 翻轉(zhuǎn)整數(shù)

Given a 32-bit signed integer, reverse digits of an integer.

Example 1:

Input: 123
Output: 321

Example 2:

Input: -123
Output: -321

Example 3:

Input: 120
Output: 21

Note:
Assume we are dealing with an environment which could only store integers within the 32-bit signed integer range: [?231,  231 ? 1]. For the purpose of this problem, assume that your function returns 0 when the reversed integer overflows.

翻轉(zhuǎn)數(shù)字問題需要注意的就是溢出問題,看了許多網(wǎng)上的解法,由于之前的 OJ 沒有對溢出進(jìn)行測試,所以網(wǎng)上很多人的解法沒有處理溢出問題也能通過 OJ?,F(xiàn)在 OJ 更新了溢出測試,所以還是要考慮到。為什么會存在溢出問題呢,由于int型的數(shù)值范圍是 -2147483648~2147483647, 那么如果要翻轉(zhuǎn) 1000000009 這個(gè)在范圍內(nèi)的數(shù)得到 9000000001,而翻轉(zhuǎn)后的數(shù)就超過了范圍。博主最開始的想法是,用 long 型數(shù)據(jù),其數(shù)值范圍為 -9223372036854775808~9223372036854775807, 遠(yuǎn)大于 int 型這樣就不會出現(xiàn)溢出問題。但實(shí)際上 OJ 給出的官方解答并不需要使用 long,一看比自己的寫的更精簡一些,它沒有特意處理正負(fù)號,仔細(xì)一想,果然正負(fù)號不影響計(jì)算,而且沒有用 long 型數(shù)據(jù),感覺寫的更好一些,那么就貼出來吧:

解法一:

class Solution {
public:
    int reverse(int x) {
        int res = 0;
        while (x != 0) {
            if (abs(res) > INT_MAX / 10) return 0;
            res = res * 10 + x % 10;
            x /= 10;
        }
        return res;
    }
};

在貼出答案的同時(shí),OJ 還提了一個(gè)問題 To check for overflow/underflow, we could check if ret > 214748364 or ret < –214748364 before multiplying by 10. On the other hand, we do not need to check if ret == 214748364, why? (214748364 即為 INT_MAX / 10)

為什么不用 check 是否等于 214748364 呢,因?yàn)檩斎氲膞也是一個(gè)整型數(shù),所以x的范圍也應(yīng)該在 -2147483648~2147483647 之間,那么x的第一位只能是1或者2,翻轉(zhuǎn)之后 res 的最后一位只能是1或2,所以 res 只能是 2147483641 或 2147483642 都在 int 的范圍內(nèi)。但是它們對應(yīng)的x為 1463847412 和 2463847412,后者超出了數(shù)值范圍。所以當(dāng)過程中 res 等于 214748364 時(shí), 輸入的x只能為 1463847412, 翻轉(zhuǎn)后的結(jié)果為 2147483641,都在正確的范圍內(nèi),所以不用 check。

我們也可以用 long 型變量保存計(jì)算結(jié)果,最后返回的時(shí)候判斷是否在 int 返回內(nèi),但其實(shí)題目中說了只能存整型的變量,所以這種方法就只能當(dāng)個(gè)思路擴(kuò)展了,參見代碼如下:

解法二:

class Solution {
public:
    int reverse(int x) {
        long res = 0;
        while (x != 0) {
            res = 10 * res + x % 10;
            x /= 10;
        }
        return (res > INT_MAX || res < INT_MIN) ? 0 : res;
    }
};

到此,關(guān)于“C++怎么實(shí)現(xiàn)翻轉(zhuǎn)整數(shù)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!


網(wǎng)頁名稱:C++怎么實(shí)現(xiàn)翻轉(zhuǎn)整數(shù)-創(chuàng)新互聯(lián)
本文鏈接:http://weahome.cn/article/dsdgjh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部