Алгоритм Карацубы
Я продолжаю получать эти ошибки при запуске своей программы, кто-нибудь может обнаружить ошибку? У меня нет опыта использования рекурсии, и я мог испортить базовый сценарий. Мое тестирование состоит из двух чисел одинаковой длины, и моя цель - умножить два больших числа без использования встроенного класса. Метод add просто берет две строки, которые являются числами, и добавляет их, я проверил, и это работает, независимо от того, насколько большие числа.
Ошибка NumberFormatException: для входной строки: "" Integer.parseInt(Integer.java:592)
public static String mu (String value1, String value2){
int length1 = value1.length();
int length2 = value2.length();
//If one value has more digits than the other, add zeroes to the front...
int temp1;
int temp2;
int multiply;
if (length1==1 || length2 ==1){
temp1 = Integer.parseInt(value1);
temp2 = Integer.parseInt(value2);
multiply = temp1*temp2;
return multiply +"" ;
}else if (length1 ==0 || length2 ==0){
return "";
}
int firstHalf = length1/2;
int secondHalf = length1 - firstHalf;
String value1First = value1.substring(0, firstHalf);
String value1Second = value1.substring(firstHalf, secondHalf);
String value2First = value2.substring(0, firstHalf);
String value2Second = value2.substring(firstHalf, secondHalf);
String ac = mu (value1First, value2First);
String ad = mu (value1First, value2Second);
String bc = mu(value1Second, value2First);
String bd = mu(value1Second, value2Second);
String zeroesToAdd= null;
String zeroesToAdd2 = null;
for (int i=0; i<length1; i++){
zeroesToAdd = "0"+ zeroesToAdd;
}
for (int i=0; i<length1/2; i++){
zeroesToAdd2 = "0"+ zeroesToAdd2;
}
String firstPart = ac + zeroesToAdd;
String secondPart = (add(ad,bc))+zeroesToAdd2;
String thirdPart = bd;
String add1 = add(firstPart, secondPart);
String add2;
return add(add1, thirdPart);
}
1 ответ
Ошибка NumberFormatException: для входной строки: "" Integer.parseInt(Integer.java:592)
вызывается кодом
Integer.parseInt(value1) or
Integer.parseInt(value2)
Возможно, вы захотите попробовать добавить больше случаев для комбинации длин строк (1,1) (1,0) (0,1) (0,0). Следующий код может помочь!
if (length1==1 && length2 ==1){
temp1 = Integer.parseInt(value1);
temp2 = Integer.parseInt(value2);
multiply = temp1*temp2;
return multiply +"" ;
}else if (length1 ==0 && length2 ==0){
return "";
}
else if (length1 ==0 && length2 ==1){
return value2;
}
else if (length1 ==1 && length2 ==0){
return value1;
}
Надеюсь, поможет!