解题思路:


        输入数字部分->判断长度部分->分割数字部分->长度输出->正序输出->反序输出

注意事项:

        输入数是整型

        没有写负整形长度判断部分

        更注重纯数字处理,提供一种清晰的解决思路


参考代码:

#include<iostream>
#include<math.h>
using namespace std;
int digit(int *num) {//长度判断 
	if (*num >= 0) {//正数长度判断 
		for (int i = 1;; i++) {
			if (pow(10, i) > *num)return i;//若是10的i次方大于输入数就返回次方值 
		}
	}
	return 0;
}
int main() {
	int num = 0,//输入数 
	    dig = 0;//长度 
	    
	cin >> num;//输入数字 
	dig = digit(&num);//获取 长度 
	int number[dig];//分割后的值保存位置 
	
	for (int i = dig - 1, i1 = 0, n, n1 = num, n2; i >= 0; i--, i1++) {
		n2 = pow(10, i);//简化过程
		n = n1 / n2;//获取 最高位数字
		n1 = n1 % n2;//保留 去除了最高位的值
		number[i1] = n;//保存 分割完的值
	}
	
	cout << dig << '\n';//长度打印 
	
	for (int i = 0; i < dig; i++) {//正序打印 
		cout << number[i];
		if (i < dig - 1)cout << ' ';
	}
	cout << '\n';
	for (int i = dig - 1; i >= 0; i--) {//反序打印 
		cout << number[i];
	}
	return 0;
}
点赞(0)
 

0.0分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论