对于这个在实际的编程题中应用比较多,做了一个总结。
基础思路
...
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++;
}
反之也可以将字符串转化为整数,不过本质是一样的,就不多说了。
刚开始写博客,有不对的地方请多多指出,谢谢?。
版权声明:本文为weixin_52070171原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。