这道题还是挺简单的(第一次写博客就挑一个简单的练练手)
绝对不是挑软柿子捏 ,话不多说就直接放题目和题解了
问题描述
输入一个5位整数,求出其各数位数值,并按照从高位到低位的顺序输出,如:输入12345,输出为1 2 3 4 5。
输入说明
输入一个五位正整数。
输出说明
按数位从高到低依次输出,各数位之间以一个空格相分隔。
输入样例
96237
输出样例
9 6 2 3 7
题解
方法一:
#include<stdio.h>
int main()
{
int a,b,c,d,e,f,g,h,k;
scanf("%d",&a);
b=a/10000;
c=a%10000;
d=c/1000;
e=c%1000;
f=e/100;
g=e%100;
h=g/10;
k=g%10;
printf("%d %d %d %d %d\n",b,d,f,h,k);
return 0;
}
这个解法只适用于题目要求数据比较小的时候,一旦当数据变大,人为设置许多变量,进行取余取整后存入变量再输出就不太现实了。所以这个解法只建议用在以后C1考试以及题目很简单懒得写更高算法时使用。
方法一的改进:
#include<stdio.h>
int main(){
int num;
scanf("%d",&num);//读取用户输入的数据
int a[100],count=0;//count用于记录数组a的长度
while(num>0){
a[count]=num%10;//存储所给数据的,某一数位上的数字
num/=10;
count++;
}
for(int i=count-1;i>=0;i--){
printf("%d ",a[i]);
}//因数组a存储时顺序颠倒,所以需要倒序输出
return 0;
}
改进后的思想也是存储每个数位的数字后输出,但是有一点不同:不用手动设置许多变量,只用一个数组就可以存储。
这可以很大程度上方便我们。需要注意的是,在此处存储数据数位数字时,因为是通过从低位向高位依次取余得到的,所以题解中数组a中存储的数字为所给数据的倒序。
那么输出时就需要 倒 序 输 出 数组a,这样才会使显示出的数据为正序。倒序的倒序是正序
我记得这个思想在后续还会在挺多题目中出现的,要记住哦!
ps:
听学长学姐说西电的编程上机考试都是每天早上的第一场最难,然后难度随着时间依次递减,这种说法不一定正确,但是我经历过的每一场确实是这样。
一个室友计算机导论期中考试的时候是早上第一场,然后她没写完233333,,,我的C1考试也是第一场,其中的C语言试题不难但是比想象中的要难,需要用到的知识还挺多,其中有很重要的一步就是需要用到方法二讲的这个思想。
方法二:
#include<stdio.h>
int main(){
char restore[5];
scanf("%s",restore);
for(int i=0;i<5;i++){
printf("%c ",restore[i]);
}
return 0;
}
这个方法是一个捡漏划水的算法~~~~
简单来讲就是,输入数据的时候就不要把他当作一个整数去看待,直接放到字符串数组,然后需要输出的时候直接输出就好啦!
Summary
这篇文章到这里就结束啦~
第一次写所以写的不是很好,有哪里写错或者不清楚的地方欢迎指正