当前位置: 代码迷 >> Java相关 >> 急java矩阵相乘,各路大神都来看一看啊解决办法
  详细解决方案

急java矩阵相乘,各路大神都来看一看啊解决办法

热度:730   发布时间:2016-04-22 22:49:06.0
急!!!!!!!!!!!java矩阵相乘,各路大神都来看一看啊

(1) 设计和编写代表矩阵的Matrix类。该类包括矩阵行列数变量int rows和int cols,矩阵数据数组double data[][],构造方法Matrix()、Matrix(int rows,int cols)、Matrix(int rows,int cols,double data[][]),获取某元素值的方法getData(int row,int col),设置某元素值的方法setData(int row,int col,double value),计算两个矩阵的乘积的方法multiply(Matrix m)以及toString()等内容。
(2) 编写测试类MatrixTest,并在该类中创建两个矩阵对象,计算其乘积。
(1) 编写Matrix类
(2) 编写MatrixTest类。在该类中通过键盘输入方式确定所要创建的两个矩阵的行列数,根据行列数随机生成数据或键盘输入,并通过setData方法生成矩阵的内容。
(3) 计算矩阵的乘积,并把结果通过toString方法输出到屏幕上


//import java.util.Scanner;
class Matrix
{
int rows;
int cols;
double data[][];
void Matrix()
{
rows=0;
cols=0;
data=new double[rows][cols];

}
void Matrix(int rows,int cols)
{
this.rows=rows;
this.cols=cols;
data=new double[this.rows][this.cols];
}
void Matrix(int rows,int cols,double data[][])
{
this.rows=rows;
this.cols=cols;
data=new double[this.rows][this.cols];
//this.data=data[rows][cols];
for(int i=0;i<rows;i++)
for(int j=0;j<cols;j++)
{
this.data[i][j]=data[i][j];
}
}
double getData(int row,int col)
{
//for(int i=0;i<row;i++)
//for(int j=0;j<col;j++)
//{
//data[row][col]
//}
data=new double[row][col];
return data[row][col];
}
void setData(int row,int col,double value)
{
data=new double[row][col];
this.data[row][col]=value;
}
double[][] multiply(Matrix m)
{
Matrix n=new Matrix();
for(int i=0;i<m.rows;i++){
for(int j=0;j<this.cols;j++){
n.data[i][j]=0;
for(int k=0;k<m.cols;k++)
n.data[i][j]+=m.data[i][k]*this.data[k][j];
}
}
return n.data;
}
/*
String toString(Matrix m,Matrix n)
{
for(int i=0;i<m.rows;i++)
for(int j=0;j<this.cols;j++)
return n.data[i][j]+" ";
return " ";
}*/
void print(Matrix n)
{
for(int i=0;i<n.rows;i++)
for(int j=0;j<n.cols;j++){
System.out.print(n.data[i][j]+" ");
System.out.println();}
}

}
class MatrixTest

{
public static void main(String[] args) 
{
System.out.println("helloworld");
Matrix x=new Matrix();
Matrix k=new Matrix();
x.Matrix(2,3);
System.out.println("helloworld");
for(int i=0;i<2;i++)
for(int j=0;j<3;j++)
{
x.setData(i,j,(i+1)*(j+2));
}
System.out.println("helloworld");
double b[][]={{1,5,2,8},{5,9,10,-3},{2,7,-5,-18}}; 
Matrix y=new Matrix();
y.Matrix(3,4,b);
k.data=y.multiply(x);
y.print(k);

}
}


Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException:0
  at Matrix.setData(MatrixTest.java:41)
  at MatrixTest.main(MatrixTest.java:85)


for(int i=0;i<2;i++)
for(int j=0;j<3;j++)
{
x.setData(i,j,(i+1)*(j+2));
}

这样赋值难道有错误码?
void setData(int row,int col,double value)
{
data=new double[row][col];
this.data[row][col]=value;
}
还是这个函数写错了啊?




------解决方案--------------------
multiply核心算法没有改你的,你自己改吧
------解决方案--------------------
Java code
class Matrix {    int rows;    int cols;    double data[][];    public Matrix() {    }    public Matrix(int rows, int cols) {        this.rows = rows;        this.cols = cols;        data = new double[rows][cols];    }    public Matrix(int rows, int cols, double data[][]) {        this.rows = rows;        this.cols = cols;        this.data = data;    }    double getData(int row, int col) {        return data[row][col];    }    void setData(int row, int col, double value) {        this.data[row][col] = value;    }    public double[][] multiply(Matrix m) {        Matrix n = new Matrix();        n.data = new double[m.rows][this.cols];        for (int i = 0; i < m.rows; i++) {            for (int j = 0; j < this.cols; j++) {                n.data[i][j] = 0;                for (int k = 0; k < m.cols; k++)                    n.data[i][j] += m.data[i][k] * this.data[k][j];            }        }        return n.data;    }    void print(Matrix n) {        for (int i = 0; i < n.rows; i++) {            for (int j = 0; j < n.cols; j++) {                System.out.print(n.data[i][j] + "\t");            }            System.out.println();        }    }}public class MatrixTest{    public static void main(String[] args) {        Matrix x = new Matrix(3, 3);        for (int i = 0; i < x.rows; i++)            for (int j = 0; j < x.cols; j++) {                x.setData(i, j, (i + 1) * (j + 2));            }        double b[][] = { { 1, 5, 2, 8 }, { 5, 9, 10, -3 }, { 2, 7, -5, -18 } };        Matrix y = new Matrix(b.length, b[0].length, b);        double d[][] = y.multiply(x);        Matrix k = new Matrix(d.length, d[0].length, d);        y.print(k);    }}
  相关解决方案