赞
踩
提取数字的每一位,可以使用取余和除法的组合来实现。
代码如下:
int ival;
deque numbers;
cin >> ival;
while(ival) {
//注意对 10 取余得到的是当前数字的最后一位
numbers.push_front(ival % 10);
ival /= 10;
因为对10取余得到的是当前数字的最后一位,比如1234%10 的结果是4,所以记录结果的时候必须将每次取余得到的数字放到已经提取出的部分结果的前面。
对于STL容器 deque或者list,这可以通过push_front()操作来实现。如果对结果的记录不使用这种可以在序列前端插入元素的结构,比如用vector来记录结果,那么最后采用逆序输出也是可以的。扩展资料:
1、循环提取方法:
代码:
while (n) {
printf("%d ", n % 10);
n /= 10;
}
putchar(10);
2、直接将数字转换为字符串,然后转换为字符数组输出。
代码:
int n=12345;
char[] chars=String.valueOf(n).toCharArray();
for(int j=0;j
System.out.print(chars[j]+" ");
}
运行效果:
3、整除法
代码:
int n=12345;
List list=new ArrayList();
for(int i=10000;i>=1;i/=10){
list.add(n/i);//将商添加到list中,就是当前的位数。12345/10000=1所以第一位是1
n=n-(n/i)*i;//用原来的数减去上一位的大小;12345变为2345
}
for(int x:list){
System.out.print(x);
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。