题目描述:
给出一个不多于 5 位的整数,要求:
1、求出它是几位数
2、分别输出每一位数字
3、按逆序输出各位数字,例如原数为 321,应输出 123
输入:
一个不大于5位的数字
输出:
一共三行,第一行:位数
第二行: 用空格分开的每个数字,注意最后一个数字后没有空格
第三行: 按逆序输出这个数
样例输入:
12345
样例输出:
5
1 2 3 4 5
54321
解题思路:
先定义一个数组用来存放每一位数字,再定义一个 n 作为输入的数,接着定义一个 number 来记录是几位数。
定义一个 for 循环,n % 10 的值赋给 num[],这样就可以获取得最后一个数;n = n / 10 向前进位,n 是没有小数位的。此时 num[] 这个数组里面的数字和输入的顺序是相反的。
再定义一个 for 循环,倒过来输出 num[],记住用空格分开的每个数字,注意最后一个数字后没有空格。
最后按照 num[]的顺序输出,也就是逆序输出。
参考代码:
#include<iostream> using namespace std; int main() { int num[5]; //定义一个有 5 个元素的数组 int n; int number = 0; //记录数位 cin >> n; //获取输入的数 for (int i = 0; i < 5; i++) { // if (n == 0) break; //如果输入的数为 0 则退出这个循环 else { num[i] = n % 10; //获取最后一位数,num[0] 为最后一个数,num[1] 是倒数第二个数 n = n / 10; //n 向前进 1 位,无小数点 number++; } } cout << number << endl; //输出数位 for (int i = number - 1; i >= 0; i--) { if (i != 0) { //如果 num[i] 不是最后一个数,则加一个空格 cout << num[i] << " "; } else cout << num[i]; //输出最后一个数 } cout << endl; //换行 for (int i = 0; i < number; i++) { cout << num[i]; //按照 num[i] 顺序输出 } return 0; }
本地运行结果如下图:
0.0分
114 人评分
#include <stdio.h> #include <math.h> int main() { int i,j,m=0,n=0; scanf("%d",&i); j=i; while(i)//位数 { i /=10; n++; } printf("%d\n",n); i=j; while(i)//空格输出 { m =i / pow(10,n - 1); i -= m * pow(10,n-1); n--; if(i<0) break; printf("%d ",m); } printf("\n"); n=0;//逆输出 while(j) { n =j % 10; printf("%d",n); j /= 10; } return 0; } 小白的我写出来的,纯数学方法……
要是输入的数字中间有零,那岂不是玩完了。。。。
修仙ing 2019-10-11 14:15:42 |
你不会是个憨憨吧,有限制条件没看到吗?n==0就终止,不会往下去执行了。
#include<iostream> #include<string.h> using namespace std; int main(){ char a[20]; cin>>a; int len=strlen(a); cout<<"共有"<<len<<"位数字"<<endl; for(int i=len;i>=0;i--){ cout<<a[i]; } return 0; } 谁能告诉我这个代码明明是对的,我在自己编译器上试过了,提交时却编译错误
为什么这个编译错误 #include<iostream> using namespace std; int main() { int num[5]; int n; int number=0; cin>>n; for(int i=0;i<5;i++) if(n!=0) { num[i]=n%10; n/=10; number++; } cout<<number<<endl; for(int i=number-1;i>=0;i--) { if(i!=0) cout<<num[i]<<" "; else cout<<num[i]; } cout<<endl; for(int i=0;i<number;i++) cout<<num[i]; return 0; }
输入的数字是0,不就GG了
ThenSea 2018-12-20 08:22:13 |
说得对,建议答主再加一个if语句,把n==0的情况也概括进去,比如:#include<iostream> using namespace std; int main() { int number=0,str[5],n; cin>>n; if(n!=0) { for(int i=0;i<5;i++) { if(n==0) break; else { str[i]=n%10; n=n/10; number++; } } cout<<number<<endl; for(int i=number-1;i>=0;i--) { if(i!=0) cout<<str[i]<<" "; else cout<<str[i]<<endl; } for(int i=0;i<number;i++) cout<<str[i]; } else { cout<<1<<endl; cout<<0<<endl; cout<<0<<endl; } return 0; }
我觉得此逻辑 不错!
毛林甫 2018-10-20 12:40:51 |
#include<stdio.h> int main() {int a,b,c,d,e,f; scanf("%d",&a); b=a/10000; c=a/1000%10; d=a/100%10; e=a%100/10; f=a%10; if((a/10000)>0) printf("%d\n",5); else if((a/1000)>0) printf("%d\n",4); else if ((a/100)>0) printf("%d\n",3); else if((a/10)>0) printf("%d\n",2); else if(a>0) { printf("%d\n",1);} printf("%d %d %d %d %d\n",b,c,d,e,f); printf("%d%d%d%d%d\n",f,e,d,c,b); return 0; }
【回文数(二)】 (C语言代码)浏览:940 |
C语言训练-排序问题<2> (C++代码)浏览:935 |
C语言训练-计算:t=1-1/(2*2)-1/(3*3)-...-1/(m*m) (C语言代码)浏览:799 |
A+B for Input-Output Practice (II) (C语言代码)浏览:1043 |
本人酷爱递归实现很多问题,这里也是浏览:632 |
【计算直线的交点数】 (C语言代码)浏览:1501 |
三角形 (C语言代码)浏览:965 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:468 |
矩形面积交 (C++代码)浏览:1204 |
C语言程序设计教程(第三版)课后习题11.8 (C语言代码)浏览:756 |