xdoj_21数位输出

本文介绍了两种C语言解决数位输出的方法,包括基础解法和优化解法。基础解法通过手动设置多个变量进行取余和整除操作,而优化解法利用数组存储数位,避免了大量变量的使用。此外,还提到了一种更简单的通过字符串处理的解决方案。文章强调了在编程考试中早场难度可能较大的现象,并提醒读者注意数据处理的灵活性和效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这道题还是挺简单的(第一次写博客就挑一个简单的练练手)
绝对不是挑软柿子捏 ,话不多说就直接放题目和题解了

问题描述

输入一个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
这篇文章到这里就结束啦~
第一次写所以写的不是很好,有哪里写错或者不清楚的地方欢迎指正

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值