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