首页 > 试题广场 >

数根

[编程题]数根
  • 热度指数:5486 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32M,其他语言64M
  • 算法知识视频讲解
数根可以通过把一个数的各个位上的数字加起来得到。如果得到的数是一位数,那么这个数就是数根;如果结果是两位数或者包括更多位的数字,那么再把这些数字加起来。如此进行下去,直到得到是一位数为止。
比如,对于24 来说,把2 和4 相加得到6,由于6 是一位数,因此6 是24 的数根。
再比如39,把3 和9 加起来得到12,由于12 不是一位数,因此还得把1 和2 加起来,最后得到3,这是一个一位数,因此3 是39 的数根。
现在给你一个正整数,输出它的数根。

输入描述:
输入包含多组数据。

每组数据数据包含一个正整数n(1≤n≤10E1000)。


输出描述:
对应每一组数据,输出该正整数的数根。
示例1

输入

24
39

输出

6
3
import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        while(sc.hasNext()){
            String s = sc.nextLine();
            while(s.length() > 1){
                char[] ch = s.toCharArray();
                int num = 0;
                for(int i = 0;i < ch.length;i++){
                    num += ch[i] - '0';
                }
                s = String.valueOf(num);
            }
            System.out.println(s);
        }
    }
}

发表于 2022-04-27 09:59:35 回复(0)
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        while(input.hasNext()){
            String a=input.next();
            int num;
            do{
                num=0;
                for(int i=0;i<a.length();i++){
                    num+=a.charAt(i)-48;
                }
                a=num+"";
            }while(num>=10);
            System.out.println(num);
        }
        input.close();
    }
}
发表于 2018-04-10 10:12:18 回复(0)
import java.util.*;
public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		while (sc.hasNext()) {
			String s = sc.next();
			System.out.println(fun(s));
		}
	}
	public static int fun(String s) {
		int res = 0;
		for (int i = 0; i < s.length(); i ++ ) {
			res += Integer.parseInt(String.valueOf(s.charAt(i)));
		}
		if(res < 10) return res;
		return fun(res + "");
	}
}

发表于 2016-10-07 22:58:03 回复(0)