输出整数的每一位

思路:

  • 例如输入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;
    }
}

运行结果:

猜你喜欢

转载自blog.csdn.net/weixin_43939602/article/details/111941276