7. Reverse Integer - Easy
Posted fatttcat
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了7. Reverse Integer - Easy相关的知识,希望对你有一定的参考价值。
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.
判断是否溢出:rev是上一轮累加的结果,先把当前值减去个位数,再除以10,和之前的rev比较是否相同,如果不同说明精度丢失、溢出了,返回0;如果相同,更新rev,进入下一轮循环
time: O(log_10(x)), space: O(1)
class Solution { public int reverse(int x) { int rev = 0; while(x != 0) { int tmp1 = x % 10; int tmp2 = rev * 10 + tmp1; if((tmp2 - tmp1) / 10 != rev) return 0; rev = tmp2; x /= 10; } return rev; } }
以上是关于7. Reverse Integer - Easy的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode:7. Reverse Integer(Easy)
LeetCode之Easy篇 ——Reverse Integer