你好,我从代码战争中得到了这个问题。
"编写一个函数,持久性,它接受一个正参数 num 并返回它的乘法持久性,这是你必须将数字乘以 num 直到达到个位数的次数。">
我在应用该方法时遇到了一些麻烦。这就是我到目前为止所拥有的。
public static int digital_root(int n) {
// ...
char[] characters = Integer.toString(n).toCharArray();
int sum = 0;
String number=Integer.toString(n);
int lengNum=number.length();
String firstChar=number.substring(0,1);
String secondChar=number.substring(1,2);
for(int i=0;i<=lengNum;i++){
int a;
number.substring(i,i+1);
number.substring(i+1,i+2);
}
for (char character : characters) {
int x = Integer.parseInt(Character.toString(character));
sum += x;
}
if (sum > 10) {
return digital_root(sum);
} else {
return sum;
}
}
由于我不知道 n 的长度,它可能是 100000000
我知道这是关键
for(int i=0;i<=lengNum;i++){
int a;
number.substring(i,i+1);
number.substring(i+1,i+2);
}
但是我的大问题来了,我可以将number.substring(i,i+1);
的值存储到一个变量中,比如Int a = number.substring(i,i+1);
然后用可变Int b=number.substring(i+1,i+2);
做同样的事情
然后返回 a*b 但如何做a*b*c*d*........
然后我将不得不在 for 循环中做
if(number<10){
return number;
}else{
//continue multiplying
}
我有以下错误:
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.franco.mac.any/com.franco.mac.any.MainActivity}: java.lang.StringIndexOutOfBoundsException: length=2; index=3
你只是想要这样的东西吗?如果你想让它处理非常大的数字,你可以使用BigInteger。
public static int persistence(int num) {
int numberOfTimes = 0;
int temp;
while (num > 9) {
temp = 1;
while (num > 0) {
temp *= num % 10;
num /= 10;
}
num = temp;
numberOfTimes++;
}
return numberOfTimes;
}