求助,C++编写程序,提示用户输入一个正整数,计算出该数字的位数并把找出每一位上的数字。

嵌入头文件cmath后,可用函数pow计算一个数x的n次方,格式为pow(x,n)。

输入数字12345,程序运行结果为
12345是一个5位数
各位上的数字从高到低分别为:
1 2 3 4 5

将数字格式化成字符串,字符串的长度就是位数
int x;
CString cs;
cs.format("%d",x);
int length = cs.Getlength(); //这个就是位数
排序的话,还是以字符串为基础,选择排序就行追问

= =·!那个。。怎么选择排序阿。。刚开始学。。不是很懂。。。可以详细说下吗?万谢。。。

追答

选择排序,先选择第一个数,而后与后面的数进行比较,然后进行交换
for (int i = 0; i<length -1;i++)
{
for(int j =i+1;j<length ;j++)
{
if (atoi(cs[i]) < atoi(cs[j]))
{
//进行交换
char c = cs[i];
cs[i] = cs[k];
cs[k] = c;
}
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2018-08-19
以下程序能满足你的要求,包括逆序输出各个位数:
/*
**获取数字num的长度
*/
int getLength(int num)
{
int i = 1;
int temp = num;
while(temp/10 != 0)
{
++i;
temp /= 10;
}
return i;
}
/*
**顺序输出数字num的各个位数
*/
void outputEveryNumber(int num)
{
int temp = num;
int length = getLength(num);
int flag = 1;
for(int i =1;i<length;++i)
{
flag *= 10;
}
while(flag != 1)
{
printf("%d%c",temp/flag,' ');
temp %= flag;
flag /= 10;
}
printf("%d%c",temp,' ');
}
/*
**逆序输出数字num的各个位数
*/
void reversedOutput(int num)
{
int flag = num;
while(flag != 0)
{
printf("%d%c",flag%10,' ');
flag /= 10;
}
}本回答被网友采纳
相似回答