编写程序题, 根据要求编写一个Java类,补充到代码中。 定义Matrix(矩阵)类,使用二维数组实现矩阵,实现两个矩阵的乘法。要求如下:
-
4个变量:row(行数),column(列数), matrix( int型二维数组),reader( Scanner对象)。
-
根据程序需求定义构造方法。
-
inputMatrix方法:从键盘读入一个矩阵,读入行数和列数,创建矩阵,然后读入元素值方法。
-
multiply方法:两个矩阵相乘,并返回乘积矩阵。
(两个矩阵的乘法:一个m×n的矩阵a(m,n)乘一个n×p的矩阵b(n,p),会得到一个m×p的矩阵c(m,p)。矩阵的行数和列数自定。)
方法声明:
public static Matrix inputMatrix(); //从键盘读入一个矩阵,并返回矩阵
Matrix multiply(Matrix mat); //两个矩阵相乘,并返回乘积矩阵。
裁判测试程序样例:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Matrix firstMat=Matrix.inputMatrix();
Matrix secondMat=Matrix.inputMatrix();
//display(firstMat.matrix); display(secondMat.matrix);
Matrix productMat=firstMat.multiply(secondMat);
display(productMat.matrix);
}
//display方法:打印二维数组元素到屏幕
public static void display(int[][] array){
for(int i=0; i<array.length; i++){
for(int j=0; j<array[i].length; j++){
if(j==array[i].length-1) {
System.out.println(array[i][j]);
}
else {
System.out.print(array[i][j]+" ");
}
}
}
}
}
/* 请在这里填写答案 */
输入样例:
2 2
1 2
3 4
2 2
2 3
4 5
输出样例:
在这里给出相应的输出。例如:
10 13
22 29
代码
class Matrix {
int row;
int column;
int[][] matrix;
static Scanner reader = new Scanner(System.in);
public static Matrix inputMatrix() {
Matrix ret = new Matrix();
ret.row = reader.nextInt();
ret.column = reader.nextInt();
ret.matrix = new int[ret.row][ret.column];
for(int i = 0; i < ret.row; i++) {
for(int j = 0; j < ret.column; j++) {
ret.matrix[i][j] = reader.nextInt();
}
}
return ret;
}
Matrix multiply(Matrix mat) {
Matrix ret = new Matrix();
ret.row = row;
ret.column = mat.row;
ret.matrix = new int[row][mat.column];
for(int i = 0; i < row; i++) {
for(int j = 0; j < mat.column; j++) {
for(int k = 0; k < column; k++) {
ret.matrix[i][j] += matrix[i][k] * mat.matrix[k][j];
}
}
}
return ret;
}
}