题目:
给定一个 32 位有符号整数,将整数中的数字进行反转。
示例 1:
输入: 123 输出: 321
示例 2:
输入: -123 输出: -321
示例 3:
输入: 120 输出: 21
注意:
假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−231, 231 − 1]。根据这个假设,如果反转后的整数溢出,则返回 0。
思路:这个代码其实我提交一次错一次才知道思路。。刚开始用余数和整除把百十位分开然后再合起来,很麻烦,条件很多。
直接转成字符串,再通过[::-1]的写法把字符串反转,很方便而且代码也很少。
- 转成字符串
- 判断第一个字符是否为‘-’ ,即是是否为负号
- 如果是负号就从下标为1的字符切片(主要为了去掉负号),并且用[::-1]反转字符串,这里[::-1]的意思就是从开始到结束,每次以-1的step取值。
- 如果正好从下标为0开始切片。反转完成后转换成整型,因为题目要求有取值范围,所以要判断是否>2147483647或<-2147483647
- 完成
代码:
python
class Solution: def reverse(self, x): """ :type x: int :rtype: int """
# 转成字符串 b = str(x) if b[0] == '-': b = b[1:][::-1] b = -int(b) if b < -2147483647: return 0 else: return(b) else: b = b[::-1] b = int(b) if b > 2147483647: return 0 else: return(b)
c#
public class Program { public int Reverse(int x) { string strx = x.ToString(); int result; int length = strx.Length; if (strx[0] == '-') { strx = strx.Substring(1,length-1); var revx = strx.Reverse().ToArray(); string a = new string(revx); if (int.TryParse(a, out result)) { return -result; } else { return 0; } } else { var revx = strx.Reverse().ToArray(); string a = new string(revx); if (int.TryParse(a, out result)) { return result; } else { return 0; } } } static void Main(string[] args) { int x = -1534236469; Program pro = new Program(); int a = pro.Reverse(x); Console.WriteLine(a); Console.ReadKey(); } }