7-8 求整数的位数及各位数字之和 (10 分)

对于给定的正整数N,求它的位数及其各位数字之和。

输入格式:
输入在一行中给出一个不超过10^​9​​的正整数N。

输出格式:
在一行中输出N的位数及其各位数字之和,中间用一个空格隔开。

输入样例:

321

输出样例:

3 6

代码部分:

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		try (// TODO Auto-generated method stub
		Scanner in = new Scanner(System.in)) {
			int n;
			int sum=0,num=0;
			n = in.nextInt();
			for(;n!=0;) {    //此处可用while循环
				sum = sum+n%10;
				num++;
				n = n/10;
			}
			System.out.println(num+" "+sum);
			in.close();
		}
	}

}

拆分整型数字 n 基本方法 (从后往前取):
① a[ i ] = n % 10 (取最后一个数字/低位数字存入数组,此题中不需要)
② sum = sum + a[ i ] ; num++ …… (进行计数,累加等操作)
③ n = n / 10 (整除更新n,目的是消去已经取得的数字,可类比于左移)
④ 进行循环,依次取数 / 计数 / 累加等操作。
java刚入门小白,如有错误或优化欢迎大佬们的指点!

### 使用 Python 计算整数位数及其各位数字之和 以下是两种方法实现该功能:一种基于递归函数,另一种通过将数字转换为字符串处理。 #### 方法一:递归法解 此方法利用递归来逐步提取每一位数字并累加其值。同时可以通过取对数值的方式计算位数[^1]: ```python def sum_digits_recursive(n): if n == 0: return 0 else: return (n % 10) + sum_digits_recursive(n // 10) def count_digits_recursive(n): if n == 0: return 0 else: return 1 + count_digits_recursive(n // 10) number = int(input("请输入一个整数: ")) digit_sum = sum_digits_recursive(number) digit_count = count_digits_recursive(number) print(f"数字 {number} 的各位数字之和为: {digit_sum}") print(f"数字 {number} 的总位数为: {digit_count}") ``` #### 方法二:字符串转换法 这种方法先将输入的整数转成字符串形式,再逐一遍历每个字符完成相应的操作[^2]: ```python def sum_and_count_digits_string_method(n): str_n = str(abs(n)) digit_sum = sum(int(digit) for digit in str_n) digit_count = len(str_n) return digit_sum, digit_count number = int(input("请输入一个整数: ")) sum_result, count_result = sum_and_count_digits_string_method(number) print(f"数字 {number} 的各位数字之和为: {sum_result}") print(f"数字 {number} 的总位数为: {count_result}") ``` 以上两段代码别展示了如何采用不同策略解决相同问题,并且都提供了清晰的结果输出方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值