解题思路:这题可以分成三个用户自定义函数来实现3个功能

注意事项:这是个人想法,没有看题解

参考代码:

#include <stdio.h>
int Num(int sum);
void separateDigits(int num);
void reverseDigits(int num);
int main()
{
	int sum,number;
	scanf("%d",&sum);
	number=Num(sum);
	separateDigits(sum);
	reverseDigits(sum);
	return 0;
}
int Num(int sum)
{
	int number=0;
	if(sum<0)
	{
		sum=-sum;
	}
	if(sum==0)
	{
		return 1;
	}
	while(sum!=0)
	{
		sum=sum/10;
		number++;
	}
	printf("%d\n",number);
}
void separateDigits(int sum)
{
	int num[5];
	int count=0;
	int i;
	//提取数字
	while(sum>0)
	{
		num[count]=sum % 10;
		sum=sum / 10;
		count++;
	}
	//遍历每一个数字
	for (i = count - 1; i > 0; i--) 
	{
        printf("%d ", num[i]);
    }
    printf("%d\n", num[0]); // 输出最后一位,不加空格
}
void reverseDigits(int sum)
{
	int reversed = 0;
    while (sum > 0) {
        reversed = reversed * 10 + (sum % 10);  // 提取最后一位并构造逆序数字
        sum /= 10;  // 去掉最后一位
    }

    printf("%d\n", reversed);
}


点赞(1)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论