给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。


 

输入这个数,把这个数字拆分成各个字符,再转成int整数类型相加,然后与10比较,小于10的话就输出结果;大与10的话就继续循环;这里运用了定义方法,因为需要多次的转化相加,所以这样就会更简洁。

package com.lianchunxz.Demo01;
import java.util.Scanner;
public class SelfSum {
 public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        String n = input.next();
        int num = Integer.parseInt(n);
        if(num>=0){
            do{
                int a = selfmun(num);
                num=a;
            }while(num>=10);
            System.out.println("这个数的各位加起来之后再加最后得到的一位数是:"+num);
        }else{
            System.out.println("请输入一个正整数:");
        }
    }

    public static int selfmun(int i){
        String s = String.valueOf(i);
        int len = s.length();
        int selfmun=0;
        for (int j=0;j<len;j++) {
            String b = String.valueOf(s.charAt(j));
            int c = Integer.parseInt(b);
            selfmun += c;
        }return selfmun;
    }
}

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



猜您在找 Leetcode练习(Python):第258题:各位相加:给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。(如何在类里面写递归) java基础练习 给定一个正整数m,统计m的位数,分别打印每一位数字,再按照逆序打印出各位数字。 2、牛牛想对一个数做若干次变换,直到这个数只剩下一位数字。 变换的规则是:将这个数变成 所有位数上的数字的乘积。比如285经过一次变换后转化成2*8*5=80. 问题是,要做多少次变换,使得这个数变成个位 例子:循环语句--给定一个不超过5位的正整数,判断该数的位数,依次打印出个位、十位、百位、千位、万位的数字。 给出一个不多于5位的整数,要求 1、求出它是几位数 2、分别输出每一位数字 3、按逆序输出各位数字,例如原数为321,应输出123 给出一个不多于5位的正整数,要求:1.求出它是几位数2.分别输出每一位数字3.按逆序输出各位数字,例如原数321应输出123 给一个不多于5位的正整数,要求:①求出它是几位数;②分别输出每一位数字;③按逆序输出各位数字,例如原数为321,应输出123 给一个不多于5位的正整数,要求:①求出它是几位数;②分别输出每一位数字;③按逆序输出各位数字,例如原数为321,应输出123。 jquery 获取时间 一位数则补零
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM