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


 1 import java.util.Scanner;
 2 
 3 /**
 4  * 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。
 5 
 6     示例:
 7 
 8     输入: 38  输出: 2
 9     解释: 各位相加的过程为:3 + 8 = 11, 1 + 1 = 2。 由于 2是一位数,所以返回 2。
10  */
11 public class TestSum {
12     public static void main(String[] args) {
13         Scanner scanner = new Scanner(System.in);
14         while (scanner.hasNext()) {
15             int num = scanner.nextInt();
16             System.out.println("输出:" + addDigits(num));
17             // System.out.println("输出:" + addDigits02(num));
18         }
19         scanner.close();
20     }
21 
22     //1.for/while/递归,可以如下直接处理,或者放到int数组,或者转成String, charAt(i),
23     // 如下的做法最简单
24     public static int addDigits(int num) {
25         int sum = 0;
26         while (num > 9) {
27             sum = 0;
28             while (num > 0) {
29                 sum += num % 10; //个位
30                 num /= 10; // 十位。。。
31             }
32             num = sum;
33         }
34         return num;
35     }
36 
37     /**
38      *  进阶写法 : 不使用循环或者递归,且在 O(1) 时间复杂度内解决这个问题
39         题解 : 假设一个三位数整数n=100a+10b+c,变化后addn=a+b+c;
40         两者的差值n-addn=99a+9b,差值可以被9整除,说明每次缩小9的倍数
41         那么我们可以对res=num%9,若不为0则返回res,为0则返回9
42      * @param num
43      * @return
44      */
45     public static int addDigits02(int num) {
46         if (num == 0) {
47             return 0;
48         }
49         return (num % 9 == 0) ? 9 : num % 9;
50     }
51 }

 


免责声明!

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



猜您在找 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数 202008xx给定一个整数n(1<=n<=1000000000),要求从个位开始分离出它的每一位数字,从个位开始按照从低位到高位的顺序依次输出每一位数字(奥赛一本通p64 4题) 给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。 给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。 【c语言】输入一个整数,将每一位数字输出 给定两个非空链表来表示两个非负整数。位数按照逆序方式存储,它们的每个节点只存储单个数字。将两数相加返回一个新的链表。 输读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。 leetcode给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字 Leetcode练习(Python):第415题:字符串相加:给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和。 把int放在一个char数组里(用于处理每一位数字)
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM