今天开始学Java 如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的矩阵C
2018-03-10 13:40
786 查看
题目描述
如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的矩阵C。这个矩阵的每个元素是由下面的公式决定的:原型:voidmatrix_multiply(int *m1,int *m2,int *r, int x, int y, int z);输入参数: int *m1:x行y列的矩阵(array1[x][y]) int *m2:y行z列的矩阵(array2[y][z]) int x:矩阵m1的行数 int y:矩阵m1的列数/矩阵m2的行数 int z:矩阵m2的列数 输出参数: int *r:矩阵m1, m2相乘的结果(array3[x][z]) 返回值: void
输入描述:
输入说明:1、第一个矩阵的行数
2、第一个矩阵的列数和第二个矩阵的行数
3、第二个矩阵的列数
4、第一个矩阵的值
5、第二个矩阵的值
输出描述:
输出两个矩阵相乘的结果示例1输入
2 2 2 3 8 8 0 9 0 18 9
输出
171 72 72 0
public class Main{
public static void matric(int [][] a,int [][]b,int a_row,int b_col,int y ){
int[][] c = new int [a_row][b_col];
for(int i =0 ; i<a_row;i++){
for (int j=0;j<b_col;j++){
int sum = 0;
for(int k = 0;k<y;k++){
sum = sum+a[i][k]*b[k][j];
}
c[i][j] = sum;
}
}
for(int i =0;i<a_row;i++){
for(int j = 0;j<b_col-1;j++){
System.out.print(c[i][j]+" ");
}
System.out.println(c[i][b_col-1]);
}
}
public static void main(String[] args){
Scanner sc= new Scanner(System.in);
while(sc.hasNext()){
int matric1_row = sc.nextInt();
int y = sc.nextInt();
int matric2_col = sc.nextInt();
int[][] matric1 = new int[matric1_row][y];
int[][] matric2 = new int[y][matric2_col];
for (int i =0 ;i<matric1_row;i++){
for (int j=0;j< y;j++)
{
matric1[i][j]=sc.nextInt();
}
}
for (int j=0;j<y;j++ ){
for(int k = 0;k <matric2_col;k++){
matric2[j][k]=sc.nextInt();
}
}
matric(matric1,matric2,matric1_row,matric2_col,y);
// System.out.print("\n");
}
}
}
相关文章推荐
- 今天开始学Java 输入一个单向链表和一个节点的值,从单向链表中删除等于该值的节点,删除后如果链表中无节点则返回空指针。
- 编写一个程序用于执行矩阵的乘法。 m1是一个x行y列的矩阵,m2是y行z列的矩阵。 这两个矩阵应该相乘,结果存储在r中,它是x行z列的矩阵。
- java实现矩阵乘法public class MatrixMultiply { //A=A*B 将相乘的结果赋给A public static void Multiply(double[][
- 今天开始学Java 给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。
- 今天开始学习JAVA!
- Introduction to Java Programming编程题7.6<两个矩阵相乘>
- 今天开始学Java 给定n个字符串,请对n个字符串按照字典序排列。
- 51nod-1140-矩阵相乘结果的判断
- 转圈显示的Java程序和两矩阵相乘
- 从今天开始,这个blog就是我的笔记了,java学习笔记!wulllllllllllllllllllla!!!
- 今天开始学Java 接受一个有字母和数字以及空格组成的字符串,和一个字符
- HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。你会不会被他忽悠住?
- [Java] 获取今天的开始时间
- 今天开始学Java 输入一个正整数,按照从小到大的顺序输出它的所有质数的因子
- 使用Java的输入输出流技术将Input.txt的内容逐行读出,每读出一行就顺序为其添加行号(从1开始,逐行递增),并写入到另一个文本文件Output.txt中
- 今天开始做java winform方面的开发
- 将对称矩阵压缩存储,实现矩阵相乘,输出相乘后结果(用二维数组)
- 矩阵相乘-c++代码实现及运行实例结果
- 今天开始学java!
- 矩阵相乘strassen-c++代码实现及运行实例结果