С++
Дана матриця розміру M на N. У кожному стовпці матриці знайти максимальний
елемент.
Ответы
Відповідь:
#include <iostream>
#include <cstdlib>
#include <time.h>
using namespace std;
void randarr(int **arr,int n,int m){
for(int i = 0; i < n; i++){
for(int j = 0; j < m; j++){
arr[i][j] = rand() % 10 + 1;
}
}
}
void printarr(int **arr,int n,int m){
for(int i = 0; i < n; i++){
for(int j = 0; j < m; j++){
cout << arr[i][j] << "\t";
}
cout << endl;
}
}
void maxcols(int **arr,int n, int m){
int max = 0,counter = 1;
for(int i = 0; i < n; i++){
for(int j = 0; j < m; j++){
if(arr[j][i] > max){
max = arr[j][i];
}
}
cout << "Максимальний елемент в " << counter << " стовпцi = " << max << endl;
max = 0;
counter++;
}
}
int main(){
srand(time(NULL));
setlocale(LC_ALL , "Ukrainian");
int n,m;
cout << "Введiть кiлькiсть рядкiв n: ";
cin >> n;
cout << "Введiть кiлькiсть стовпцiв m: ";
cin >> m;
int **arr = new int *[n];
for (int i = 0; i < n; i++)
arr[i]=new int[m];
randarr(arr,n,m);
printarr(arr,n,m);
maxcols(arr,n,m);
for (int i = 0; i < n; i++)
delete[]arr[i];
delete[]arr;
return 0;
}