温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

[LeetCode]7. Reverse Integer

发布时间:2020-07-10 07:29:29 来源:网络 阅读:571 作者:風子余 栏目:编程语言

Reverse digits of an integer.

Example1: x = 123, return 321
Example2: x = -123, return -321


整数反转:假如输入123,则输出321;


解题:

1)如果输入x为负数,那么先取负数的绝对值。并修改flag值为0.

2)通过除十取余开始逐步取出个位数值,并将该数值依次加到反转数值中。

3)对输入数字除十取商。重复第二步,直到商为零。

4)如果是负数输入,则将绝对值取反。


说明:

1)输出结果变量val声明为long long类型,是防止操作过程中出现int整数溢出。

2)返回值:如果输出结果大于int型的最大值或者小于int型的最小值时(溢出),那么返回0.否则返回正常输出结果。

int reverse(int x) 
{
    int flag = -1; 
    if ( x < 0 ) { 
        x = x * flag;
        flag = 0;
    }
    
    int tmp = 0;
    long long val = 0;
    
    while ( x ) { 
        tmp = x % 10; 
        val = val * 10 + tmp;
        x   = x / 10; 
    }
     
    if ( flag == 0 ) { 
        val = -1 * val;
    } 
      
    return val > INT_MAX || val < INT_MIN ? 0 : val;
}


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI