原题链接:[编程入门]数字的处理与判断
题目描述:
给出一个不多于 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分
74 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
#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; }#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; } 小白的我写出来的,纯数学方法……