Дана матрица A размера [latex]m*n[/latex]. Получить транспонированную матрицу A*(ее размер [latex]n*m[/latex]).
n | m | А | А* | ||||
5 | 4 |
|
|
||||
5 | 6 |
|
|
||||
4 | 3 |
|
|
Код программы:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
#include <iostream> using namespace std; int main() { int n, m; cin>>n>>m; int M[n][m]; for(int i=0; i<n; i++) { for(int j=0; j<m; j++) { cin >> M[i][j]; } } int M1[m][n]; for(int i=0; i<m; i++) { for(int j=0; j<n; j++) { M1[i][j]=M[j][i]; } } for(int i=0; i<m; i++) { for(int j=0; j<n; j++) { cout<<M1[i][j]<<" "; } cout<<endl; } return 0; } |
Считываем матрицу [latex]n*m[/latex], а затем создаем транспонированную матрицу, в которой строки исходной матрицы являются столбцами и наоборот. Выводим A*.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
import java.util.*; import java.lang.*; import java.io.*; class Ideone { public static void main (String[] args) throws java.lang.Exception { Scanner in = new Scanner(System.in); int n, m; n = in.nextInt(); m = in.nextInt(); int [][]M = new int [n][m]; for(int i=0; i<n; i++) { for(int j=0; j<m; j++) { M[i][j] = in.nextInt(); } } int [][]M1 = new int [m][n]; for(int i=0; i<m; i++) { for(int j=0; j<n; j++){ M1[i][j]=M[j][i]; } } for(int i=0; i<m; i++) { for(int j=0; j<n; j++) { System.out.println(M1[i][j]); } System.out.println("\n"); } } } |
Задача 710, а не 170.
Будьте внимательнее.
Зачтено.