• c语言:求逆序后四位


    逆序后四位

    任务描述

    程序每次读入一个至少4位数的正整数,然后输出其后4位按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入57000,输出应该是7。

    输入格式:
    每个测试是一个正整数。

    输出格式:
    输出逆序的数。

    输入示例

    34500
    
    • 1

    输出示例

    54
    
    • 1

    思路

    求逆序的话,就要利用好%10和/10这两个重要技巧,%10可以求个位数,/10可以求除去个位数的其他位上的数字是多少,本来想着用当前个位数不为0作为条件从而判断输出,代码如下

    #include 
    int main() {
        int num,count;
        scanf("%d", &num);
    
        // 从个位开始依次取出后四位数字并逆序输出
        int last_four_digits = 0;
        count = 0; //用于记录次数
        while (count <4) {
            int digit = num % 10; // 获取个位数字
            if(digit!=0)
                printf("%d",digit);
            num /= 10; // 去掉已经处理过的最后一位数字
            count++;
        }
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    但这种情况有个bug,比如34504,结果输出后为454,并不是4054。后来在朋友帮助下找到另一种思路,就是用一个变量累加,当变量大于0时才输出,这样就避免了全0和中间有0的情况,代码如下。

    #include 
    int main() {
        int num,count,cnt;
        scanf("%d", &num);
    
        // 从个位开始依次取出后四位数字并逆序输出
        int last_four_digits = 0;
        count = 0; //用于记录次数
        cnt=0; //用于记录数字之和
        while (count <4) {
            int digit = num % 10; // 获取个位数字
            cnt+=digit; //将数字累加到cnt中
            if(cnt>0)
                printf("%d",digit);
            num /= 10; // 去掉已经处理过的最后一位数字
            count++;
        }
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
  • 相关阅读:
    UWB系统的定位精度影响因素(二)
    Vue2数据双向绑定的原理(Object.defineProperty)
    Vue3自定义组件v-model双向绑定
    laravel框架 - 事件与监听器
    Leetcode 剑指 Offer II 053. 二叉搜索树中的中序后继
    005-BSP学习笔记-Uboot图形化配置
    剑指 Offer II 036. 后缀表达式
    指令手册术语缩写
    Leetcode2065-最大化一张图中的路径价值
    Go定时任务源码 - robfig/cron
  • 原文地址:https://blog.csdn.net/qq_62717777/article/details/136464913