C++定义一个5×5的数组,用随机函数产生4×4的数据,把每行中前4个元素中最小的放在最后一列,再把前四行中每列最大数放在最后一行。 如产生4×4的数据: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 结果为: 1 2 3 4 1 5 6 7 8 5 9 10 11 12 9 13 14 15 16 13 13 14 15 16 13
时间: 2023-12-31 12:04:40 浏览: 57
数据结构C++算法
好的,这是一个比较典型的数组操作题目,可以按照以下步骤来实现:
1. 定义一个5×5的二维数组,用随机函数产生4×4的数据。
```cpp
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
int main() {
// 定义5x5的二维数组
int arr[5][5];
// 用当前时间作为随机种子
srand(time(nullptr));
// 产生4x4的随机数据
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 4; j++) {
arr[i][j] = rand() % 100 + 1;
}
}
// 输出原始数据
cout << "Original data:" << endl;
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 4; j++) {
cout << arr[i][j] << "\t";
}
cout << endl;
}
return 0;
}
```
2. 把每行中前4个元素中最小的放在最后一列。
```cpp
// 把每行中前4个元素中最小的放在最后一列
for (int i = 0; i < 4; i++) {
// 先假设第一个元素最小
int min_val = arr[i][0];
int min_col = 0;
// 从第二个元素开始比较
for (int j = 1; j < 4; j++) {
if (arr[i][j] < min_val) {
min_val = arr[i][j];
min_col = j;
}
}
// 把最小值放在最后一列
arr[i][4] = min_val;
arr[i][min_col] = arr[i][3];
arr[i][3] = arr[i][2];
arr[i][2] = arr[i][1];
arr[i][1] = arr[i][0];
}
// 输出处理后的数据
cout << "Data after processing:" << endl;
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 5; j++) {
cout << arr[i][j] << "\t";
}
cout << endl;
}
```
3. 把前四行中每列最大数放在最后一行。
```cpp
// 把前四行中每列最大数放在最后一行
for (int j = 0; j < 4; j++) {
// 先假设第一个元素最大
int max_val = arr[0][j];
int max_row = 0;
// 从第二个元素开始比较
for (int i = 1; i < 4; i++) {
if (arr[i][j] > max_val) {
max_val = arr[i][j];
max_row = i;
}
}
// 把最大值放在最后一行
arr[4][j] = max_val;
arr[max_row][j] = arr[3][j];
arr[3][j] = arr[2][j];
arr[2][j] = arr[1][j];
arr[1][j] = arr[0][j];
}
// 输出最终结果
cout << "Final result:" << endl;
for (int i = 0; i < 5; i++) {
for (int j = 0; j < 5; j++) {
cout << arr[i][j] << "\t";
}
cout << endl;
}
return 0;
}
```
阅读全文