国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

藍橋杯-算法訓練-矩陣乘法-Java

2019-11-14 11:12:58
字體:
來源:轉載
供稿:網友

藍橋杯-算法訓練-矩陣乘法-java

問題描述

  輸入兩個矩陣,分別是m*s,s*n大小。輸出兩個矩陣相乘的結果。

輸入格式

  第一行,空格隔開的三個正整數m,s,n(均不超過200)。   接下來m行,每行s個空格隔開的整數,表示矩陣A(i,j)。   接下來s行,每行n個空格隔開的整數,表示矩陣B(i,j)。   

輸出格式

m行,每行n個空格隔開的整數,輸出相乘後的矩陣C(i,j)的值。

樣例輸入

2 3 2 1 0 -1 1 1 -3 0 3 1 2 3 1

樣例輸出

-3 2 -8 2

提示 矩陣C應該是m行n列,其中C(i,j)等于矩陣A第i行行向量與矩陣B第j列列向量的內積。 例如樣例中C(1,1)=(1,0,-1)(0,1,3) = 1 0 +0*1+(-1)*3=-3

思考

在第一個矩陣的列數和第二個矩陣的行數相等時才能實現矩陣的相乘,這里我定義二維數組來表示矩陣,通過for循環來進行矩陣的相乘。

代碼

import java.util.Scanner;public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int m = 0 , s = 0 , n = 0 ; if(scanner.hasNext()){ //輸入m,s,n m = scanner.nextInt() ; s = scanner.nextInt() ; n = scanner.nextInt() ; } //定義兩個矩陣,行列數分別為m,s與s,n int arr1[][] = new int[m][s] ; int arr2[][] = new int[s][n] ; for(int i = 0 ; i < m ; i ++){ //輸入第一個矩陣 for(int j = 0 ; j < s ; j++){ if(scanner.hasNext()){ arr1[i][j] = scanner.nextInt() ; } } } for(int i = 0 ; i < s ; i++){ //輸入第二個矩陣 for(int j = 0 ; j < n ; j++){ if(scanner.hasNext()){ arr2[i][j] = scanner.nextInt() ; } } } int arr[][] = new int[m][n] ; //定義一個相乘后的矩陣,矩陣的行數與列數為m,n for(int i = 0 ; i < m ; i++){ //進行矩陣相乘 for(int j = 0 ; j < n ; j++){ for(int x = 0 ; x < s ; x ++){ //arr[i][j] = arr1[i][1] * arr2[1][j] + ... + arr1[i][s-1] * arr2[s-1][j] arr[i][j] += arr1[i][x] * arr2[x][j] ; } System.out.PRint(arr[i][j] + " "); } System.out.println(); } }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 平南县| 延津县| 商水县| 富顺县| 介休市| 晋宁县| 扶风县| 辉县市| 武穴市| 洱源县| 澄迈县| 潢川县| 临安市| 广宗县| 郴州市| 尚义县| 拉萨市| 巨野县| 锡林浩特市| 梅州市| 南涧| 水城县| 革吉县| 策勒县| 大埔区| 漳州市| 潢川县| 乌拉特前旗| 资中县| 丽江市| 靖西县| 平阳县| 杭锦旗| 邢台县| 鄂州市| 白朗县| 太保市| 柳林县| 黄骅市| 扎鲁特旗| 怀宁县|