给定一个32位有符号整数,将整数中的数字进行反转
(假设我们的环境只能存储32位有符号整数,其数值范围是[−2(31), 2(31) − 1])。根据这个假设,如果反转后的整数溢出,则返回0
示例1:输入123 输出321
示例2:输入-123,输出-321
示例3:输入120,输出21
思路
1.数字-->转为字符串-->字符串转为列表-->反转列表-->如果第一位为0,去掉-->如果最后一位为负数,把它赋值给第一位-->列表转为字符串-->字符串转为数字-->判断数字是否是在在规定范围内-->在,返回该数字;不在,返回0
- x > 0,flag = 1; x<0,flag = -1
x 转为字符串:s = str(abs(x))
反转为字符串:s1 = s[::-1]
字符串转为整数:x1=int(s1)*flag
If x1 >2147483647 or x1 < -2147483648:
return 0
else:
return x1