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

Posted 浪川宣哲

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了给定一个非负整数 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;
    }
}

 

以上是关于给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。的主要内容,如果未能解决你的问题,请参考以下文章

Python笔试题:给定一个非负整数num,反复将各个位上的数字相加,直到结果为一位数杭州多测师杭州多测师_王sir

leetcode 258. 各位相加 (python)

各位相加

各位相加

LeetCode--258--各位相加*

力扣 258各位相加