计算一个整数的位数
只需要设计一个计时器,因为C语言中除法只留下整数部分,所以可以拿数字/10;数字位数即为循环次数,待n为个位时n/10=0,然后循环结束。
#include<stdio.h>
int main()
{
int n;
int count = 0;
scanf("%d",&n);
if(n == 0)//n为0的情况,个人感觉无位数,退出
{
return 0;
}
else
{
while(n)
{
n=n/10;//每次去掉数字最后一位
count++;//循环一次计数器+1
}
}
printf("%d",count);
return 0;
}
关于如何获取整数各个位
对于这个在实际的编程题中应用比较多,做了一个总结。
基础思路
...
int i=123,a;
a = i%10;
printf("a=%d",a);
输出的便是i的个位数
a=3
然后知道通过 i/10 便可"清除"个位数
由此我们便可以通过循环此方法获取各个位数
...
int i=123,a,b,c;
a = i%10;
i/=10;
b = i%10;
i/=10;
c = i%10;
i/=10;
printf("a=%d,b=%d,c=%d",a,b,c);
输出的a,b,c便是 i 的个位数,十位数,百位数
于是我们便知道将整数反转的方法
...
int i;
long rex = 0;//反转后的整数
while(i != 0){
rex = rex*10 + i % 10;
i = i / 10;
}//溢出判断暂时忽略
将整数反转后那我们又可以得到将整数按位存入数组的方法
int i,j,count=0;
int nums[numsSize];//需要存入的数组
long rex = 0;
while(i != 0){
rex = rex*10 + i % 10;
i = i / 10;
}
...
while(rex != 0)
{
j = rex % 10;//获取个位数
nums[count] = j;
rex/=10;
count++;
}
反之也可以将字符串转化为整数,不过本质是一样的,就不多说了。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。