[英]How to find sum of separate digits of a number?
我正在尝试解决Euler项目#16:
2 ^ 15 = 32768,其位数之和为3 + 2 + 7 + 6 + 8 = 26。
2 ^ 1000的数字总和是多少?
这个问题看起来很简单,但是我没有使用模数10,而是尝试解决以下问题:
public class Main {
public static void main(String[] args) {
long number = (long) Math.pow(2,100);
long sum=0;
String number2 = String.valueOf(number);
char[] digits = number2.toCharArray();
for (char digit : digits) {
sum = sum + digit;
}
System.out.println(sum);
}
}
但是,它给出了错误的答案,我看不到我的错误,这样是否可以解决这个问题?
long
无法容纳该数字。 您必须使用可以的数据类型进行重写。
有关指针,请参见Java中的大数 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.