题解 | NC57反转数字

反转数字

http://www.nowcoder.com/practice/1a3de8b83d12437aa05694b90e02f47a

NC57: 反转数字

分析:coding之前,我们应该明确的几点。

1.什么是数字的反转?
这一点结合题意与测试用例已经很明确,不再赘述。
2.关于数据范围?
一个32为有符号整数:
图片说明
不同语言对边界的处理不同,详见参考代码。

解法一:数学

思路:要将数字倒序进行展示,要做的就是获取到每一位上面的单个数字。方法很简单,将目标数字%10即可。
比如:对于数字123,按照如上思路可以这样写:

  • 123 % 10-->3
  • 12 % 10 -->2
  • 1 % 10-->1
    那么问题来了,怎么从让数字从百位降到十位,甚至其他位数呢?
    有一个很简单的技巧,将目标数字/10即可(别忘了编程语言的除法特性)。
    综合以上的作除与取模运算,可以得到:
    图片说明

Java参考代码

import java.util.*;


public class Solution {
    /**
     * 
     * @param x int整型 
     * @return int整型
     */
    public int reverse (int x) {
         long n=0;
        while (x!=0){
            n = n*10+x%10;
            x = x/10;
        }
//三元表达式并强转
        return (int)n==n?(int

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

小白专属-牛客题解 文章被收录于专栏

专注于牛客平台编程题题解,文字+图解。内容很细,小白友好系列

全部评论
这么喜欢用long?不看题目说明?
1 回复 分享
发布于 2022-05-24 17:54

相关推荐

吃不饱的肱二头肌很想退休:tnnd 我以为选妹子呢,亏我兴高采烈的冲进来😠
投递快手等公司10个岗位
点赞 评论 收藏
分享
过往烟沉:我说什么来着,java就业面就是广!
点赞 评论 收藏
分享
8 1 评论
分享
牛客网
牛客企业服务