国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

LeetCode-7. Reverse Integer

2019-11-11 03:55:03
字體:
供稿:網(wǎng)友

1.題目描述

Reverse digits of an integer.

Example1: x = 123, return 321

Example2: x = -123, return -321

Note:

The input is assumed to be a 32-bit signed integer. Your function should return 0 when the reversed integer overflows.

2.我的分析思路

我之前的想法是將數(shù)字首先判斷數(shù)字是正數(shù)還是負(fù)數(shù),然后走不同的分支。接著將數(shù)字轉(zhuǎn)換為字符串,然后將字符串倒序輸出。

這個(gè)想法感覺沒啥問題,但是實(shí)施起來的時(shí)候遇到了一些問題。字符串倒序輸出,轉(zhuǎn)換成char數(shù)組,然后倒序訪問char數(shù)組,放到新的數(shù)組中。然后再拼接成字符串,然后將字符串轉(zhuǎn)換為數(shù)字。

實(shí)現(xiàn)起來比較麻煩,然而并沒有想到其他的好的實(shí)現(xiàn)方法。

3.其他的思路

看大家的討論內(nèi)容,發(fā)現(xiàn)了一個(gè)比較精妙的實(shí)現(xiàn)方法,現(xiàn)分享給大家。

public static int reverse(int x) throws Exception { if (x > Integer.MAX_VALUE || x < Integer.MIN_VALUE) { return 0; } int revNum = 0; int digit = 0; // 關(guān)鍵也就是這三行的代碼 while (x != 0) { digit = x % 10; revNum = digit + revNum * 10; x /= 10; } return revNum;}

這個(gè)算法的精妙之處,可以debug查看。每次獲取到數(shù)字的個(gè)位數(shù),然后接著將這個(gè)個(gè)位數(shù)乘以10之后,加上新的個(gè)位數(shù)。如此循環(huán),即可得到倒序輸出的數(shù)字。

妙哉!妙哉!


上一篇:篩法

下一篇:獎(jiǎng)券數(shù)目

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 资溪县| 丰城市| 阜新| 焉耆| 青州市| 南木林县| 安顺市| 湘乡市| 麻城市| 琼海市| 尼木县| 长阳| 凉山| 和硕县| 民权县| 桓台县| 辉县市| 团风县| 沾益县| 攀枝花市| 龙江县| 民县| 德格县| 宜宾县| 甘孜| 太仆寺旗| 瓦房店市| 安陆市| 浪卡子县| 宁陕县| 东丽区| 新蔡县| 肃宁县| 霍州市| 江永县| 昌乐县| 白玉县| 凤冈县| 临夏市| 浙江省| 灌南县|