43 lines
1.1 KiB
Plaintext
43 lines
1.1 KiB
Plaintext
|
class Matrix extends Vector<Vector<Integer>> {
|
||
|
|
||
|
Matrix mul_rec(Matrix m) {
|
||
|
v1;
|
||
|
v1 = new Vector<Integer>();
|
||
|
v2;
|
||
|
v2 = new Vector<Integer>();
|
||
|
i;
|
||
|
i = 0;
|
||
|
while(i < m.size()) {
|
||
|
v;
|
||
|
v = m.elementAt(i);
|
||
|
v2.addElement(v.remove(v.size()-1));
|
||
|
i++;
|
||
|
}
|
||
|
Matrix ret;
|
||
|
if (m.elementAt(0).size() > 0) {
|
||
|
ret = this.mul_rec(m);
|
||
|
}
|
||
|
else {
|
||
|
ret = new Matrix();
|
||
|
i = 0;
|
||
|
while (i < this.size()) {
|
||
|
ret.addElement(new Vector<Integer>());
|
||
|
i++;
|
||
|
}
|
||
|
}
|
||
|
i = 0;
|
||
|
while (i < this.size()) {
|
||
|
int erg = 0;
|
||
|
j;
|
||
|
j = 0;
|
||
|
while (j < v2.size()) {
|
||
|
erg = erg + this.elementAt(i).elementAt(j).intValue()
|
||
|
* v2.elementAt(j).intValue();
|
||
|
j++;
|
||
|
}
|
||
|
ret.elementAt(i).addElement(erg);
|
||
|
i++;
|
||
|
}
|
||
|
return ret;
|
||
|
}
|
||
|
}
|