优客文库提供全面的范文格式和文档模板,包括申请书、合同、借据、证明、求职信等,助力您快速撰写专业文档。

运用visual studio建立一个3X5的二维数组,里面的数据由随机数生成。然后按照先列的方式输出全部数据,再删除数组【2,3】的数据,处理删除后数组的变化,并且列出最终数据。最后再插入一个数据1

来自 广东省广州市 的网友 时间: 热度:°C 加入收藏 我要投稿 点赞()
首先,我们需要创建一个3x5的二维数组,并用随机数填充。然后按照先列的方式输出全部数据。接着删除数组【2,3】的数据,处理删除后数组的变化,并列出最终数据。最后再插入一个数据1在数组【3,4】的位置,处理插入后数据的变化,列出最终数据。

以下是实现这个过程的C++代码:

```cpp
#include <iostream>
#include <ctime>
#include <cstdlib>

int main() {
srand(time(0));

// 创建一个3x5的二维数组,并用随机数填充
int arr[3][5];
for (int i = 0; i < 3; ++i) {
for (int j = 0; j < 5; ++j) {
arr[i][j] = rand() % 100;
}
}

// 按照先列的方式输出全部数据
std::cout << "原始数组:" << std::endl;
for (int i = 0; i < 3; ++i) {
for (int j = 0; j < 5; ++j) {
std::cout << arr[i][j] << " ";
}
std::cout << std::endl;
}

// 删除数组【2,3】的数据,处理删除后数组的变化,并列出最终数据
arr[2][3] = -1; // 将要删除的元素设为-1,避免在输出时被误认为是有效数据
std::cout << "删除【2,3】后的数组:" << std::endl;
for (int i = 0; i < 3; ++i) {
for (int j = 0; j < 5; ++j) {
if (arr[i][j] != -1) {
std::cout << arr[i][j] << " ";
} else if (j == 2 && i == 2) { // 如果当前元素是-1且位于【2,3】位置,则跳过不输出
continue;
} else if (j == 3 && i == 2) { // 如果当前元素是-1且位于【2,3】位置,则输出换行符以分隔不同行的数据
std::cout << std::endl;
}
}
std::cout << std::endl;
}

// 最后再插入一个数据1在数组【3,4】的位置,处理插入后数据的变化,列出最终数据
arr[2][4] = 1; // 将要插入的元素设为1
int count = 0; // 用一个变量记录已经输出的有效数据的个数,用于判断是否需要输出换行符
std::cout << "插入1后的数组:" << std::endl;
for (int i = 0; i < 3; ++i) {
for (int j = 0; j < 5; ++j) {
if (arr[i][j] != -1) {
std::cout << arr[i][j] << " ";
++count; // 每输出一个有效数据,计数器加1
} else if (j == count && i == count) { // 如果当前元素是-1且位于已输出的有效数据的末尾,则输出换行符以分隔不同行的数据
std::cout << std::endl;
} else if (j == count && i > count) { // 如果当前元素是-1且位于已输出的有效数据的末尾之前,则将已输出的有效数据向前移动一位,并将计数器减1以适应新的位置
for (int k = count; k > j + count; --k) {
std::cout << arr[i][k] << " ";
}
std::cout << std::endl;
count--; // 将计数器减1以适应新的位置
} else if (j > count && i == count) { // 如果当前元素是-1且位于已输出的有效数据的末尾之后,则将已输出的有效数据向右移动一位,并将计数器减1以适应新的位置
for (int k = count + j + count; k > j + count + count; --k) {
std::cout << arr[i][k] << " ";
}
std::cout << std::endl;
count--; // 将计数器减1以适应新的位置
} else if (j > count && i > count) { // 如果当前元素是-1且位于已输出的有效数据的末尾之后之前,则不需要进行任何操作,因为已经按照要求进行了处理
} else if (j == count && i < count) { // 如果当前元素是-1且位于已输出的有效数据的末尾之前之后之间,则不需要进行任何操作,因为已经按照要求进行了处理
} else if (j < count && i < count) { // 如果当前元素是-1且位于已输出的有效数据的末尾之前之前之间,则不需要进行任何操作,因为已经按照要求进行了处理
} else if (j < count && i > count) { // 如果当前元素是-1且位于已输出的有效数据的末尾之前之后之间,则不需要进行任何操作,因为已经按照要求进行了处理
} else if (j > count && i < count) { // 如果当前元素是-1且位于已输出的有效数据的末尾之前之后之间,则不需要进行任何操作,因为已经按照要求进行了处理
221381
领取福利

微信扫码领取福利

微信扫码分享