王高军


私信TA

用户名:uq_90593608432

访问量:291

签 名:

等  级
排  名 11873
经  验 1005
参赛次数 1
文章发表 3
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

解题思路:


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

注意事项:

        输入数是整型

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

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


参考代码:

#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 人评分

  评论区

  • «
  • »