思路:
- 例如输入123,首先判断出有3位(第2位,第1位,第0位)
- 从高位到低位依次取出每一位
- 取出最高位1,即123/100=1;为了取出下一位,更新数字,123%100=23
- 取出下一位2,即23/10=2;为了取出下一位,更新数字,23%10=3
- 再取出最后一位3,即3/1=3
- 其中100,10,1分别是10^2,10^1,10^0,取出第几位,就是/10的几次方(第2位,第1位,第0位)
代码:
import java.util.Scanner;
public abstract class pra1214 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个整数:");
int num = sc.nextInt();
System.out.println(num + "的每一位是");
everyPosition(num);
}
//首先看有多少位
//再取出每一位输出
public static void everyPosition(int num) {
int num1 = num;
int count = 0;
while (num1 != 0) {
num1 = num1 / 10;
count++;
}
for (int i = count - 1; i >= 0; i--) {
if (i != 0) {
System.out.print(num / (ciFang(i)) + ",");
num = num % (ciFang(i));
} else {
System.out.println(num / (ciFang(i)));
}
}
}
//10的i次方
public static int ciFang(int i) {
if (i == 0) {
return 1;
}
int num = 1;
for (int j = 1; j <= i; j++) {
num *= 10;
}
return num;
}
}
运行结果: