2015-04-22 21:40:22 +02:00
|
|
|
class Matrix extends Menge<Menge<Integer>> {
|
2014-04-26 16:20:16 +02:00
|
|
|
|
|
|
|
Matrix mul_rec(Matrix m) {
|
|
|
|
v1;
|
2015-04-22 21:40:22 +02:00
|
|
|
v1 = new Menge<Integer>();
|
2014-04-26 16:20:16 +02:00
|
|
|
v2;
|
2015-04-22 21:40:22 +02:00
|
|
|
v2 = new Menge<Integer>();
|
2014-04-26 16:20:16 +02:00
|
|
|
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()) {
|
2015-04-22 21:40:22 +02:00
|
|
|
ret.addElement(new Menge<Integer>());
|
2014-04-26 16:20:16 +02:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
}
|