题目描述:
给出一个不多于 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 人评分
if(x<=9){ printf("1\n"); printf("%d\n",x); printf("%d\n",x);} else if(x>9&&x<100){ printf("2\n"); printf("%d %d\n",x/10,x%10); printf("%d%d\n",x%10,x/10);} else if(x>=100&&x<=999){ printf("3\n"); printf("%d %d %d\n",x/100,x/10%10,x%10); printf("%d%d%d\n",x%10,x/10%10,x/100);} else if(x>=1000&&x<=9999){ printf("4\n"); printf("%d %d %d %d \n",x/1000,x/100%10,x%100/10,x%10); printf("%d%d%d%d \n",x%10,x%100/10,x/100%10,x/1000);} else if(x>=10000&&x<=99999){ printf("5\n"); printf("%d %d %d %d %d\n",x/10000,x/1000%10,x/100%10,x%100/10,x%100%10); 感觉我是最麻烦的
这玩意有bug请尝试无脑方法 #include<stdio.h> main(){ int a; scanf("%d",&a); printf("5\n"); printf("1 2 3 4 5\n"); printf("54321"); }
酸奶喵喵酱 2020-11-05 18:32:00 |
你是个天才
不考虑数组,直接硬上,简单粗暴 int num, countNum = 0,num1 = 0,num2 = 0; int i,j; cin >> num; while(num != 0) { i = num % 10; j = num / 10; num = j; countNum++; num1+=i; num1*=10; } cout << countNum << endl; num1/=10; num2 = num1; while(num2 != 0){ i = num2 % 10; j = num2 / 10; num2 = j; cout << i << ' '; } cout << endl
#include<stdio.h> int main() { int usee,a[5]; int sum=0; scanf("%d",&usee); int n=0; for(int i=0; i<5; i++) { a[i]=usee%10; usee=usee/10; n++; if(usee==0)break; } printf("%d\n",n); for(int j=0; j<n; j++) { printf("%d ",a[j]); sum=sum+a[j]*pow(10,(n-j-1)); } printf("\n%d",sum); return 0; }
你们这也太复杂了吧 看看我的#include<stdio.h> int main() { int a,i,j,c[5]; scanf("%d",&a); i=0; while(a!=0) { c[i]=a%10; a=a/10; i++; } printf("%d\n",i); for(j=i-1;j>=0;j--) { printf("%d",c[j]); printf(" "); } printf("\n"); for(j=0;j<i;j++) { printf("%d",c[j]); } printf("\n"); return 0; }
#include<stdio.h> #include<stdlib.h> int main() { int str[5] = { 0 }; int sum, i=0, j=0, n = 1; scanf("%d", &sum); if (sum > 99999) return 0; while ((sum / n) > 0) //确定有几位,通过求摸来实现 { n *= 10; j++; } printf("%d\n", j); n = 1; for (i = 0; i < j; i++) //利用得到的位数值将每一位分解并存入数组中。 { str[i] = sum / n % 10; n *= 10; } for (i = j-1; i >= 0; i--)//打印每一个数。 { printf("%d ", str[i]); } printf("\n"); for (i = 0; i < j; i++)//反向打印每一个数。 { printf("%d", str[i]); } system("pause"); return 0; }
#include "stdafx.h" using namespace std; int digits(int); void number(int, int); void backwards(int, int); int main() { int num; cout << "Please input a number:"; while (cin >> num) { cout << "There are " << digits(num) << " numbers." << endl; number(num, digits(num)); backwards(num, digits(num)); cout << "Please input a number:"; } system("Pause"); return 0; } int digits(int _num) { int _digits = 1; while (_num / 10 != 0) { _digits++; _num = _num / 10; } return _digits; } void number(int _num,int _digits) { while (_digits != 0) { cout << _num / (int)pow(10, _di
#include <stdio.h> int main(int argc, char** argv) { int x,a,b,c,d,e; scanf("%d",&x); a=x/10000; b=x%10000/1000; c=x%1000/100; d=x%100/10; e=x%10; if(a!=0){ printf("5\n%d %d %d %d %d\n%d%d%d%d%d\n",e,d,c,b,a,e,d,c,b,a); } else if(b!=0){ printf("4\n%d %d %d %d\n%d%d%d%d\n",e,d,c,b,e,d,c,b); } else if(c!=0){ printf("3\n%d %d %d\n%d%d%d\n",e,d,c,e,d,c); } else if(d!=0){ printf("2\n%d %d\n%d%d\n",e,d,e,d); } else printf("1\n%d\n%d\n",e,e); return 0; }
WU-复数求和 (C++代码)浏览:2119 |
【偶数求和】 (C语言代码)浏览:588 |
数对 (C语言代码)浏览:762 |
图形输出 (C语言代码)浏览:1422 |
C语言程序设计教程(第三版)课后习题11.5 (C语言代码)浏览:1495 |
模拟计算器 (C语言代码)浏览:2366 |
C语言程序设计教程(第三版)课后习题8.4 (C语言代码)浏览:585 |
简单的a+b (C语言代码)浏览:538 |
求圆的面积 (C++代码)浮点数有误差!!!浏览:724 |
C语言程序设计教程(第三版)课后习题10.4 (C语言代码)浏览:643 |
自控原理ys 2020-06-09 22:28:37 |
#include <stdio.h> int main() { int a,i=0,k ,flag=0,a0,a1,a2,a3,a4; scanf("%d",&a); if(a>99999) { printf("不符合要求,请重新输入五位数以内的数"); return 0; } if(a==0) printf("这个数有1位 "); else { for(k=1,i=0;a>=k;k=k*10) i++; printf("这个数有%d位 ",i); } a0=a%10; a1=a/10%10; a2=a/100%10; a3=a/1000%10; a4=a/10000%10; /*if(a4>0) { printf("%d ",a4); flag=1; } if(a3>0||flag==1) { printf("%d ",a3); flag=1; } if(a2>0||flag==1) { printf("%d ",a2); flag=1; } if(a1>0||flag==1) { printf("%d ",a1); flag=1; } printf("%d",a0);*/ switch(i) { case 5:printf("%d ",a4); case 4:printf("%d ",a3); case 3:printf("%d ",a2); case 2:printf("%d ",a1); case 1:printf("%d ",a0);break; default:printf("%d ",a0); } switch(i) { case 5:printf("%d",a0);printf("%d",a1);printf("%d",a2);printf("%d",a3);printf("%d",a4);break; case 4:printf("%d",a0);printf("%d",a1);printf("%d",a2);printf("%d",a3);break; case 3:printf("%d",a0);printf("%d",a1);printf("%d",a2);break; case 2:printf("%d",a0);printf("%d",a1);break; case 1:printf("%d",a0);break; default:printf("%d",a0); } return 0; } 我的比你的还麻烦