编写程序题, 根据要求编写一个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 scanner = new Scanner(System.in);
public Matrix(int row,int column)
{
this.row=row;
this.column=column;
this.matrix = new int[row][column];
}
public Matrix()
{
;
}
// 读入
public static Matrix inputMatrix()
{
int row = scanner.nextInt();
int column = scanner.nextInt();
Matrix a = new Matrix(row,column);
for(int i=0;i<row;i++)
{
for(int j=0;j<column;j++)
{
a.matrix[i][j] = scanner.nextInt();
}
}
return a;
}
// 乘法
public Matrix multiply(Matrix mat)
{
Matrix product = new Matrix();
product.matrix = new int[this.row][mat.column];
for(int i=0;i<this.row;i++)
{
for(int j=0;j<mat.column;j++)
{
product.matrix[i][j] = 0;
for(int k=0;k<this.column;k++)
{
product.matrix[i][j] += this.matrix[i][k]*mat.matrix[k][j];
}
}
}
return product;
}
}