c语言:求逆序后四位
时间:2024-03-28 11:40:45 来源:网络cs 作者:欧阳逸 栏目:卖家故事 阅读:
阅读本书更多章节>>>>
逆序后四位
任务描述
程序每次读入一个至少4位数的正整数,然后输出其后4位按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入57000,输出应该是7。
输入格式:
每个测试是一个正整数。
输出格式:
输出逆序的数。
输入示例
34500
输出示例
54
思路
求逆序的话,就要利用好%10和/10这两个重要技巧,%10可以求个位数,/10可以求除去个位数的其他位上的数字是多少,本来想着用当前个位数不为0作为条件从而判断输出,代码如下
#include <stdio.h>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;}
但这种情况有个bug,比如34504,结果输出后为454,并不是4054。后来在朋友帮助下找到另一种思路,就是用一个变量累加,当变量大于0时才输出,这样就避免了全0和中间有0的情况,代码如下。
#include <stdio.h>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;}
阅读本书更多章节>>>>
本文链接:https://www.kjpai.cn/gushi/2024-03-28/149941.html,文章来源:网络cs,作者:欧阳逸,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
下一篇:返回列表