【JAVA】【刷题子】7.整数反转

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第25天,点击查看活动详情

一、题目与题目分析

题目

  给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。
  如果反转后整数超过 32 位的有符号整数的范围 [−231,  231 − 1] ,就返回 0。
  假设环境不允许存储 64 位整数(有符号或无符号)。
image.png
  (题目来源:力扣:7.整数反转

题目分析

  这道题和前天做的 【JAVA】【刷题子】9.回文数 有点类似。主要考核的都是数字翻转。
  整数翻转嘛,示例都比较清楚;正负符号不考虑,只考虑数字翻转就好了,就是要“123”转成“321”;“-120”就转成“-21”等等。

二、整体逻辑与主要代码

题目分析已经比较清楚了,接下来我们进入代码设计。

整体逻辑

  整数翻转嘛,但是要清楚的是,传入的是int类型,int类型的范围是-2^31~2^31-1,即-2147483648~2147483647;所以要考虑翻转后,是否超出了范围;比如“-1234567899”翻转后就是“-9987654321”;超出int整数的范围了。

主要代码

整体逻辑清晰了之后,同时也有较清楚的注释。直接来看代码吧! (如有不懂的或者更好的建议,欢迎评论区分享友友的看法哈~)

class Solution {
	public static int reverse(int x) {
		// 记录翻转后的结果(用long类型是因为x翻转后的值可能会超过Int的范围。)
		long res = 0;
		while (x != 0) { // x不为0,循环
			// 前后翻转(如2022 -> 会转为2202)
			res = res * 10 + x % 10;
			// 位数减1
			x = x / 10;
		}
		// 强转为int类型,并记录
		int resInt = (int) res;
		// 与原来的long类型的值相等,则返回翻转的数值;否则,返回0
		return resInt == res ? resInt : 0;
	}
}
复制代码

三、结果展示

image.png

四、人生总结

梦想没有什么能够阻挡,阻挡的只是自身的问题。

题目数据库

Gitee:传送门

文章小尾巴

文章写作、模板、文章小尾巴可参考:《写作“小心思”》
  感谢你看到最后,最后再说两点~
  ①如果你持有不同的看法,欢迎你在文章下方进行留言、评论。
  ②如果对你有帮助,或者你认可的话,欢迎给个小点赞,支持一下~
  我是南方者,一个热爱计算机更热爱祖国的南方人。

  (文章内容仅供学习参考,如有侵权,非常抱歉,请立即联系作者删除。)

猜你喜欢

转载自juejin.im/post/7110608644651089928