给你一个正整数数组 nums
。
nums
中的所有元素相加求和。nums
中每一个元素的每一数位(重复数位需多次求和)相加求和。返回 元素和 与 数字和 的绝对差。
注意:两个整数 x
和 y
的绝对差定义为 |x - y|
。
示例 1:
输入:nums = [1,15,6,3] 输出:9 解释: nums 的元素和是 1 + 15 + 6 + 3 = 25 。 nums 的数字和是 1 + 1 + 5 + 6 + 3 = 16 。 元素和与数字和的绝对差是 |25 - 16| = 9 。
示例 2:
输入:nums = [1,2,3,4] 输出:0 解释: nums 的元素和是 1 + 2 + 3 + 4 = 10 。 nums 的数字和是 1 + 2 + 3 + 4 = 10 。 元素和与数字和的绝对差是 |10 - 10| = 0 。
- public int differenceOfSum(int[] nums) {
- int elementSum = 0, digitSum = 0;
- for (int num : nums) {
- elementSum += num;
- digitSum += getDigitSum(num);
- }
-
- return Math.abs(elementSum - digitSum);
- }
-
- public static int getDigitSum(int num) {
- int sum = 0;
- // 15
- while (num != 0) {
- // 个位数
- sum += num % 10;
- num /= 10;
- }
- return sum;
- }