C++ 數(shù)字的反轉(zhuǎn)實(shí)現(xiàn)實(shí)例
數(shù)字的反轉(zhuǎn)
(144) (0)
Reverse digits of an integer.
Example1: x = 123, return 321 Example2: x = -123, return -321
備注:當(dāng)數(shù)字溢出時(shí),則程序返回0。
解題思路:
1、用一個(gè)變量y(初始化為0)保存改變之后的值;
2、將x的個(gè)位取下來(lái),并且y乘上10,然后對(duì)加上x(chóng);
3、判斷y-x的個(gè)位除以10,時(shí)候等于變量y(防止數(shù)字溢出),如果不等于則返回0;
4、將x等于x除以10,進(jìn)一位;
5、當(dāng)x存在時(shí),循環(huán)2~4;
6、返回y;
可能大家看不懂3過(guò)程,我用一個(gè)簡(jiǎn)單的例子來(lái)演示一下。
實(shí)現(xiàn)代碼如下:
#include<iostream> #include<windows.h> using namespace std; int reverse(int x) { int num = 0; while (x != 0) { int tail = x % 10; int newnum = num * 10 + tail; if ((newnum - tail) / 10 != num) { return 0; } num = newnum; x /= 10; } return num; }
測(cè)試用例:
int main() { cout << reverse(123) << endl; cout << reverse(-123) << endl; cout << reverse(1000000003) << endl; system("pause"); return 0; }
測(cè)試結(jié)果:
如果大家有更好的解法,歡迎大家積極討論。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
Visual Studio 2019 如何新建 Win32項(xiàng)目的方法步驟
這篇文章主要介紹了Visual Studio 2019 如何新建 Win32項(xiàng)目的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03C語(yǔ)言遞歸實(shí)現(xiàn)線(xiàn)索二叉樹(shù)
這篇文章主要介紹了C語(yǔ)言遞歸實(shí)現(xiàn)線(xiàn)索二叉樹(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10ubuntu系統(tǒng)下C++調(diào)用matlab程序的方法詳解
學(xué)習(xí)c++與matlab混合編程一般是通過(guò)c++調(diào)用matlab函數(shù),因?yàn)閙atlab具有強(qiáng)大的數(shù)學(xué)函數(shù)庫(kù),然而vc++具有界面設(shè)計(jì)靈活的優(yōu)點(diǎn),下面這篇文章主要給大家介紹了關(guān)于在ubuntu系統(tǒng)下C++調(diào)用matlab程序的方法,需要的朋友可以參考下。2017-08-08C++友元(Friend)用法實(shí)例簡(jiǎn)介
這篇文章主要介紹了C++友元(Friend)用法,對(duì)于C++的學(xué)習(xí)來(lái)說(shuō)有很好的參考價(jià)值,需要的朋友可以參考下2014-08-08DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--定點(diǎn)數(shù)模擬浮點(diǎn)數(shù)運(yùn)算及常見(jiàn)的策略
本文主要講解DSP中定點(diǎn)數(shù)模擬浮點(diǎn)數(shù)運(yùn)算及常見(jiàn)的策略,具有參考價(jià)值,需要的朋友可以參考一下。2016-06-06C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
這篇文章主要介紹了C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例,并且轉(zhuǎn)換后會(huì)統(tǒng)計(jì)二進(jìn)制1的個(gè)數(shù),實(shí)例簡(jiǎn)單明了,需要的朋友可以參考下2014-06-06C++中高性能內(nèi)存池的實(shí)現(xiàn)詳解
在 C/C++ 中,內(nèi)存管理是一個(gè)非常棘手的問(wèn)題,我們?cè)诰帉?xiě)一個(gè)程序的時(shí)候幾乎不可避免的要遇到內(nèi)存的分配邏輯。本文將通過(guò)C++實(shí)現(xiàn)高性能內(nèi)存池,感興趣的可以了解一下2022-10-10linux下C語(yǔ)言中的mkdir函數(shù)與rmdir函數(shù)
以下是對(duì)C語(yǔ)言中的mkdir函數(shù)與rmdir函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08