Я пытаюсь умножить два числа, которые являются положительными целыми числами, и они имеют одинаковое количество цифр, с делением и побегом рекурсивно, я пытаюсь сделать что-то вроде этого : T (n) = 4T (n/2) + O (n) Примечание: я знаю, что он работает в тета (n^2), и это ужасно! Это просто упражнение для меня. спасибо, и извините за мой плохой английский. :) и мой вопрос: где моя ошибка? algorithm based on this doc вот код:Умножение двух десятичных целых чисел с divide и conquer java
import java.util.Scanner;
public class main {
static int res=0;
static int stage =0;
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
char[] Num1;
char[] Num2;
String num1 = in.nextLine();
String num2 = in.nextLine();
in.close();
Num1 = num1.toCharArray();
Num2 = num2.toCharArray();
DaQMultiplay(Num1, Num2);
System.out.println(res);
}
static int DaQMultiplay(char[] num1,char[] num2){
if(num1.length<2){
stage++;
int num1sd =Integer.parseInt(new String(num1));
int num2sd =Integer.parseInt(new String(num2));
return (num1sd*num2sd);
}
stage++;
double len = num1.length;
int lenl = (int) Math.ceil(len/2);
char []ln1 = new char[lenl];
char []rn1 = new char[(int) (len-lenl)];
char []ln2 = new char[lenl];
char []rn2 = new char[(int) (len-lenl)];
for (int i = 0; i < ln1.length; i++) {
ln1[i]=num1[i];
}
for (int i = 0; i < rn1.length; i++) {
rn1[i]=num1[i+lenl];
}
for (int i = 0; i < ln2.length; i++) {
ln2[i]=num2[i];
}
for (int i = 0; i < rn2.length; i++) {
rn2[i]=num2[i+lenl];
}
System.out.print("Left Side of num1:"+stage+" ");
System.out.println(ln1);
System.out.print("Right Side of num1:"+stage+" ");
System.out.println(rn1);
System.out.print("Left Side of num2:"+stage+" ");
System.out.println(ln2);
System.out.print("Right Side of num2:"+stage+" ");
System.out.println(rn2);
res+=DaQMultiplay(ln1,ln2)*(10^((int)len));
System.out.println("res: "+res);
res+=DaQMultiplay(ln1,rn2)*10^((int) (len-lenl));
System.out.println("res: "+res);
res+=DaQMultiplay(rn1,ln2)*10^((int) (len-lenl));
System.out.println("res: "+res);
res+=DaQMultiplay(rn1, rn2);
System.out.println("res: "+res);
return 0;
}
}
выход: для num1 = 20011, num2 = 91281
20011
91281
Left Side of num1:1 200
Right Side of num1:1 11
Left Side of num2:1 912
Right Side of num2:1 81
Left Side of num1:2 20
Right Side of num1:2 0
Left Side of num2:2 91
Right Side of num2:2 2
Left Side of num1:3 2
Right Side of num1:3 0
Left Side of num2:3 9
Right Side of num2:3 1
res: 144
res: 164
res: 164
res: 0
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 1
at main.DaQMultiplay(main.java:46)
at main.DaQMultiplay(main.java:63)
at main.DaQMultiplay(main.java:61)
at main.main(main.java:19)
спасибо, он решает ошибку, но все еще есть проблема с правильностью алгоритма в шагах покорения, я не знаю, как обрабатывать 4 входящего хвоста рекурсии, мой алгоритм на основе этого документа: http: // www3. cs.stonybrook.edu/~rezaul/Fall-2012/CSE548/CSE548-lecture-2.pdf –