gpt4 book ai didi

java - android中的乘法持久化程序

转载 作者:行者123 更新时间:2023-12-02 01:55:09 25 4
gpt4 key购买 nike

您好,我遇到了来自 codewars 的问题。

“编写一个持久性函数,它接受正参数 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;
}

关于java - android中的乘法持久化程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57402298/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com