解题思路:
输入数字部分->判断长度部分->分割数字部分->长度输出->正序输出->反序输出
注意事项:
输入数是整型
没有写负整形长度判断部分
更注重纯数字处理,提供一种清晰的解决思路
参考代码:
#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 人评分
C语言训练-排序问题<1> (C语言代码)浏览:1411 |
川哥的吩咐 (C语言代码)浏览:926 |
大神老白 (C语言代码)浏览:694 |
兰顿蚂蚁 (C++代码)浏览:1160 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:723 |
C语言程序设计教程(第三版)课后习题6.11 (C语言代码)浏览:565 |
DNA (C语言描述,数据结构)浏览:909 |
C语言程序设计教程(第三版)课后习题6.2 (C语言代码)浏览:751 |
IP判断 (C语言代码)浏览:592 |
Pascal三角 (C语言代码)浏览:707 |