• Leetcode—7.整数反转【中等】


    2023每日刷题(十)

    Leetcode—7.整数反转

    在这里插入图片描述

    关于为什么要设long变量

    参考自这篇博客
    在这里插入图片描述
    在这里插入图片描述
    long可以表示-2147483648而且只占4个字节,所以能满足题目要求

    复杂逻辑版实现代码

    int reverse(int x){
        int arr[32] = {0};
        long y;
        int flag = 1;
        if(x < 0) {
            flag = -1;
            y = x;
            y = -y;
        } else {
            y = x;
        }
        int ans = 0;
        if(y == 0) {
            ans = 0;
        }
        int i = 0;
        while(y) {
            arr[i++] = y % 10;
            y /= 10;
        }
        int cnt = i;
        int pos[10] = {2, 1, 4, 7, 4, 8, 3, 6, 4, 7};
        int flag2 = 0;
        if(cnt == 10) {
            int k = 0;
            int tmp1 = 0;
            int tmp2 = 0;
    
            while(k < 10) {
                tmp1 *= 10;
                tmp2 *= 10;
                if(k == 9) {
                    if(flag == 1 && arr[k] <= pos[k]) {
                        ans = tmp1 + arr[k];
                        break;
                    } else if(flag == -1 && arr[k] <= pos[k] + 1) {
                        if(arr[k] == pos[k] + 1) {
                            ans = tmp1*(-1)-8;
                        } else {
                            ans = tmp1*(-1)-arr[k];
                        }
                        break;
                    } else {
                        ans = 0;
                        break;
                    }
                }
                tmp1 += arr[k];
                tmp2 += pos[k];
                if(tmp1 < tmp2) {
                    flag2 = 1;
                    break;
                } else if(tmp1 > tmp2) {
                    ans = 0;
                    break;
                }
                k++;
            }
        } 
        if(cnt < 10 || flag2 == 1) {
            int tmp1 = 0;
            int j = 0;
            while(j < cnt) {
                tmp1 *= 10;
                tmp1 += arr[j++];
            }
            ans = tmp1;
            if(flag == -1) {
                ans *= -1;
            }
        }
        return ans;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73

    运行结果

    在这里插入图片描述

    简洁版实现代码

    int reverse(int x){
        long ans = 0;
        // long类型:防止反转过程溢出
        long y = x;
        int d, flag;
        flag = (x < 0 ? -1 : 1);
        if(x < 0) {
            y = -y;
        }
        while(y != 0) {
            d = y % 10;
            y /= 10;
            ans = ans * 10 + d;
        }
        ans = flag * ans;
        if(ans < INT_MIN || ans > INT_MAX) {
            return 0;
        }
        return ans;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    运行结果

    在这里插入图片描述

    更简洁版实现代码

    其实也可以不判断符号

    int reverse(int x){
        long ans = 0;
        // long类型:防止反转过程溢出
        long y = x;
        int d;
        while(y != 0) {
            d = y % 10;
            y /= 10;
            ans = ans * 10 + d;
        }
        if(ans < INT_MIN || ans > INT_MAX) {
            return 0;
        }
        return ans;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

  • 相关阅读:
    30【BOM和浏览器环境概述】
    【康耐视国产案例】智能AI相机联合OSARO为Zenni眼镜实现订单履约自动化
    计算机设计大赛 深度学习OCR中文识别 - opencv python
    虚拟现实(VR)的应用场景
    Python学习打卡:day11
    Vue 依赖注入 - Provide/Inject
    离散数学复习纲要
    【Python】通过Fourier变换实现频域滤波
    Jmeter(一):jmeter概述与工作原理,安装与基本配置介绍详解
    C练题笔记之:Leetcode-137. 只出现一次的数字 II
  • 原文地址:https://blog.csdn.net/qq_44631615/article/details/134050499