当前位置: 移动技术网 > IT编程>开发语言>C/C++ > c语言经典例题:正整数求位数and求顺、逆序位数

c语言经典例题:正整数求位数and求顺、逆序位数

2018年09月30日  | 移动技术网IT编程  | 我要评论

依依影视,托尔巴拉德奖章有什么用,中海万锦熙岸业主论坛

经典例题:正整数求位数and求顺、逆序位数

题目要求:

给出一个int整形正整数,要求:

1.求出它是几位数字

2.按照逆序分别输出每位数字,例如123输出为321

3.按正序输出每位数字

分析:

一:求几位数 设置一个计数器count

1234 -> 123 去掉一个4,count+1

123 -> 12 去掉一个3,count+1

12 -> 1 去掉一个2,count+1

1 -> 空 去掉一个1,count+1

而怎么去掉这个4、3、2、1呢?

int整形除以10,可以去掉个位。即:1234/10 = 123

所以代码如下:

\

程序出现错误,figure(0)应该输出的结果为1,结果代码中没有考虑到n=0的情况。所以我们需要添加一条if()语句。

代码如下:

if(n == 0)

{

count = 1;

}

二:按照逆序分别输出每一位数字,123则输出321.

这里请看一中的分析,我们分别去掉了4、3、2、1,那么正好是1234的逆序输出。

4:1234求10的余数,得到4

123:1234除以10.得到123

所以代码如下:

\

三:按正序输出每位数字

还按照一中的思路:

1234 ->1,从1234中挑出一个1,需要:1234除以1000,1000 = 10^3 ,3 = 4 - 1,4为位数。

所以,1 = 1234/(10^(count - 1));

1234 ->234; 234 = 1234 - 1000;

234 -> 2 ,从234中挑出2·····

代码如下:

\

最后贴一下源代码:

#include

int figure(int n)//定义函数:求出n的位数

{

int count = 0; //初始化计数器,为0;

if(n == 0) //当n = 0时,这里所有的n = 0是都单独拿出来讨论。

{

count = 1;

}

while(n != 0)

{

count++;

n /= 10;

}

return count;

}

void nieverynum(int n) //定义函数:逆序输出每一位数字

{

int wei; //逆序的每一位数字

printf("逆序输出结果为:");

if(n == 0) //同样单独讨论n = 0时,下面再出现时不再注释

{

wei = 0;

printf("%d ",wei);

}

while(n != 0)

{

wei = n % 10; //得到个位的数字

n /= 10; //n变成删除个位的数字

printf("%d ",wei);

}

printf("\n");

}

void shuneverynum(int n) //定义函数:顺序输出每一位数字

{

int swei; //顺序的每一位数字

int count = figure(n); //求n是几位数字,调用figure函数,figure函数的返回值为位数;

int power = 1; //这里用一个for语句,求得1 = 1234/(10^count - 1)中的(10^(count - 1))

for(int i = 1;i < count;i++)

{

power *= 10; //即power = 10^(count - 1)

}

printf("顺序输出结果为:");

if(n == 0) //同上例

{

swei = 0;

printf("%d ",swei);

}

while(n != 0)

{

swei = n / power; //顺序的位 = 1234 除以1000

printf("%d ",swei);

n -= swei * power; //例如:123 = 1234 - 1*1000

power /= 10; //100 = 1000 除以 10 然后循环输出顺序位数字

}

printf("\n");

}

int main()

{

printf("%d\n",figure(123456));

printf("%d\n",figure(1));

printf("%d\n",figure(0));

nieverynum(1234567);

shuneverynum(1234567);

return 0;

}

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网