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

首頁 > 學院 > 開發設計 > 正文

LeetCode-7. Reverse Integer

2019-11-11 05:02:16
字體:
來源:轉載
供稿:網友

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.我的分析思路

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

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

實現起來比較麻煩,然而并沒有想到其他的好的實現方法。

3.其他的思路

看大家的討論內容,發現了一個比較精妙的實現方法,現分享給大家。

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; // 關鍵也就是這三行的代碼 while (x != 0) { digit = x % 10; revNum = digit + revNum * 10; x /= 10; } return revNum;}

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

妙哉!妙哉!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 易门县| 大悟县| 福海县| 葫芦岛市| 开远市| 克拉玛依市| 建始县| 平果县| 镇平县| 含山县| 循化| 阿拉善左旗| 海盐县| 浑源县| 嘉黎县| 新巴尔虎右旗| 陇南市| 武陟县| 新竹县| 同江市| 汉川市| 扶沟县| 静安区| 新乡县| 屯昌县| 普宁市| 宁陵县| 黄梅县| 防城港市| 岐山县| 临城县| 西畴县| 明星| 丽水市| 华坪县| 广水市| 北流市| 得荣县| 甘南县| 海门市| 静宁县|