Ⅰ 用java代码,实现m行n列矩阵的转换,即横向变为纵向,纵向变为横向,
定义2维数组,如上面的定义成a[5][3],下面的定义成b[3][5],然后取a数组的值赋给b数组
Ⅱ java二维数组实现矩阵相乘的问题
public class Matrix
{
private int value[][]; //存储矩阵元素的二维数组
public Matrix(int m, int n) //构造m行n列的空矩阵
{
this.value=new int[m][n];
}
public Matrix(int n) //构造n行n列的空矩阵
{
this(n,n);
}
public Matrix()
{
this(10,10);
}
public Matrix(int mat[][]) //构造矩阵,由数组mat提供矩阵元素
{
this(mat.length,mat[0].length);
for (int i=0; i<mat.length; i++)
for (int j=0; j<mat[i].length; j++)
this.value[i][j] = mat[i][j];
}
public int get(int i, int j) //获得矩阵第i行第j列的元素,O(1)
{
return value[i][j];
}
public void set(int i, int j, int k) //设置矩阵第i行第j列的元素,O(1)
{
value[i][j]=k;
}
public String toString() //行主序遍历,访问矩阵全部元素
{
String str="";
for (int i=0; i<value.length; i++)
{
for (int j=0; j<value[i].length; j++)
str += " "+value[i][j];
str += "\n";
}
return str;
}
public void add(Matrix b) //this和b两个矩阵相加,改变当前矩阵
{
for (int i=0; i<this.value.length; i++)
for (int j=0; j<this.value[i].length; j++)
this.value[i][j] += b.value[i][j];
}
public void minus(Matrix b) //this和b两个矩阵相减,改变当前矩阵
{
for (int i=0; i<this.value.length; i++)
for (int j=0; j<this.value[i].length; j++)
this.value[i][j] -= b.value[i][j];
}
public void multi(Matrix b)//当前矩阵=当前矩阵*b
{
if(this.value[0].length != b.value.length )
{
System.out.println("这两个矩阵不能相乘");
return ;}
Matrix temp=new Matrix(value.length,b.value[0].length);
for(int i=0;i<value.length;i++)
for(int j=0;j<b.value[0].length;j++)
{
temp.value[i][j]=0;
for(int k=0;k<value[0].length;k++)
temp.value[i][j] +=value[i][k]*b.value[k][j];
}
this.value=temp.value;
}
public Matrix transpose() //返回转置矩阵
{
Matrix trans = new Matrix(value[0].length, value.length);
for (int i=0; i<this.value.length; i++)
for (int j=0; j<this.value[i].length; j++)
trans.value[j][i]=this.value[i][j];
return trans;
}
}
class Matrix_ex
{
public static void main(String args[])
{
int m1[][]={{1,2,3},
{4,5,6}};
Matrix a=new Matrix(m1);
int m2[][]={{1,2},
{3,4},
{5,6}
};
Matrix b=new Matrix(m2);
System.out.print("Matrix a:\n"+a.toString());
System.out.print("Matrix b:\n"+b.toString());
//a.add(b);
a.multi(b);
System.out.print("Matrix a*b:\n"+a.toString());
// System.out.println("a的转置矩阵:\n"+a.transpose().toString());
}
}
你把结果放到a里了
你的代码 a[i][j] += (a[i][k] * c[k][j]);
如果a是2行4列,b是4行8列,结果应该是2行8列
a[0][7]就不存在,下标超界
应该先构造出一个结果矩阵,算完再赋值给a
Ⅲ 用JAVA编写矩阵
这样定义就可以:int[][] array = {{1,13,12,11},{2,14,17,10},{3,15,16,9},{4,5,6,7,8}};
想要查看的话:
for(int i = 0; i < array.length; i ++) {
for(int j = 0; j < array[i].length; j ++) {
System.out.println(array[i][j]);
}
}
注:java 中的二维数组中每一维的长度是可以不同的,如例子中的,前三个长度为4,第四个长度则为5,这样是允许的。