1.求出他是几位数。
用12345举例子,这是个五位数。从他的个位数开始数,去掉一个,位数加一。12345就是丢掉五位,所以是五位数字。所以利用循环就可以解决。
具体代码为:
while(n!=0)//当n不为0时,执行这个循环
{
n/=10;//去位数
count++;
}
现在的问题是如何去掉位数。可以用n/=10来解决。12345/10—1234.5因为是整除所以为1234(整数除以整数是整数)。
在定义一个计数器count,去一位就加一,直到0为止。
具体代码为下:
#include<stdio.h>
int num(long n)
{
int count=0;//定义计数器
if(n==0)//如果n是0的话,直接位数是1
return 1;
while(n!=0)//当n不为0时,执行这个循环
{
n/=10;//去位数
count++;
}
return count;
}
int main()
{
printf("%d\n",num(123456));
return 0;
}
2.分别输出每一位数字。
这个问题的关键是如何得到最高位。用12345举例:1 2 3 4 5 得到最高位将它输出,再舍去最高位,一直到0为止。
得到最高位的办法是12345/10000(取整数)(具体不固定),然后%=10000(取余数,舍去最高位)。
int fig=num(n);//得到n的位数
int power=pow(10.0,fig-1);//求出应除10的几次方
while(n!=0)
{
printf("%d ",n/power);//得到最高位
n%=power;//丢掉最高位
power/=10;
}
10000这个数不确定的原因是,它是根据输入数字的位数变化的,如果输入的数字为1234那么就为1000,以此类推。
而我们第一问已经求过输入数字是几位数
int num(long n)
{
int count=0;
if(n==0)
return 1;
while(n!=0)
{
n/=10;
count++;
}
return count;
}
还有一个问题就是去掉最高位后数字的位数会减一。例如12345去掉最高位后变为2345本来由除10000变为除1000。解决这个问题的办法就是在每次循环的时候给10000(不确定)除以10,%=10。
power/=10;//每次循环都除以10,以确保与位数相对
所以具体代码为下:
int num(long n)
{
int count=0;
if(n==0)
return 1;
while(n!=0)
{
n/=10;
count++;
}
return count;
}
void shun(long n)
{
if(n==0)
printf("0\n");
int fig=num(n);//得到n的位数
int power=pow(10.0,fig-1);//求出应除10的几次方
while(n!=0)
{
printf("%d ",n/power);//得到最高位
n%=power;//丢掉最高位
power/=10;
}
}
int main()
{
shun(12345);
return 0;
}
3.按逆序输出各位数字。
这一问只需要在第一问中丢弃的那一步之前加上打印,意思打印完以后再去掉就可以解决(得到个位再丢弃个位,直到数字为0)。
还是用12345举例子,这是个五位数。得到个位 %10,丢弃个位/=10。
代码如下:
while(n!=0)
{
printf("%d ",n%10);//直接输出得到的个位
n/=10;//去掉个位
}
按逆序输出各位数字的具体代码为:
void num(long n)
{
if(n==0)
printf("0\n");
while(n!=0)
{
printf("%d ",n%10);//直接输出得到的个位
n/=10;//去掉个位
}
}
int main()
{
num(123456);
return 0;
}