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

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

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

2019-11-14 11:46:09
字體:
來源:轉載
供稿:網友

藍橋杯-算法訓練-矩陣乘法-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(); } }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 呼图壁县| 吴桥县| 曲松县| 随州市| 德阳市| 泸西县| 枝江市| 临洮县| 皮山县| 盘山县| 洛川县| 余庆县| 罗江县| 乐陵市| 永济市| 山阳县| 海阳市| 静乐县| 兰西县| 探索| 永丰县| 子洲县| 巩留县| 安远县| 陆河县| 安西县| 邓州市| 亚东县| 柞水县| 玉树县| 屏东市| 乐都县| 新野县| 万全县| 伊春市| 大方县| 老河口市| 呼图壁县| 蓬安县| 宁波市| 中江县|