如何从上到下翻转 2D 数组?
How do i flip a 2d array from top to bottom?
我正在尝试从上到下翻转二维数组。
例如 1,2,3
4,5,6
7,8,9
into
7,8,9
4,5,6
1,2,3
我不会为您提供代码,因为 SO 不是为此而设计的,但我会向您展示必要的步骤:
- 创建与第一个阵列尺寸相同的第二个 2D 数组
- 向后循环第一个数组,并将
size - index - 1
处的每一行复制到第二个数组 - 将第一个数组替换为第二个数组
void flipArrays(int[][] arrays)
{
int[][] result = new int[arrays.length][arrays[0].length];
for(int i = 0; i < arrays.length; i++)
{
for(int y = 0; y < arrays[0].length; y++)
{
result[i][y] = arrays[arrays.length - i - 1][y];
}
}
}
我将指导您如何解决此问题。你可以在数学/伪代码中做到这一点,然后将其隐蔽到你的代码中。
- 创建一个临时数组,该数组用于包含原始数组中的翻转值,因此您不会覆盖原始数组的值。
- 将原始数组的最后一行传递给临时数组的第一行,依此类推。
您可以使用双指针方法。
在第 0 行使用一个指针(只是一个整数变量(,在第 n-1 行使用另一个指针。然后交换其中的元素。然后递增第一个并递减第二个。直到它们指向同一行或直到第一行大于第二行,您才会继续这样做。
空间复杂度:O(1)
时间复杂度:O(row*col)
伪代码
start := 0
end := row-1
while start < end
begin
for each colvar in [0..col-1]
swap arr[start,colvar] , arr[end,colvar]
start <- start + 1
end <- end - 1
end
相关文章:
- 2D数组来自文本输入,中间有空格
- 如何使用用户输入在C++中正确填充2D数组
- 如何在C++中检查2D数组中负值的输入验证
- 当我在main中声明了我的2d数组时,为什么我的程序会退出
- 如何将以逗号和空格分隔的整数读取到 2D 数组中?
- 如何在C++函数中声明静态 2D 数组?
- 如何声明一个可以在整个程序中使用的全局 2d 3d 4d .. 数组(堆版本)变量?
- 我已经阅读了很多关于 2d 数组的信息,但我在作业中使用它时遇到了麻烦
- 使用矢量将文本文件中的输入存储到 2D 数组中
- 获取 2D 数组 c++ 中的所有数字对
- 这是使用回溯的 nqueen 问题,但我使用了动态 2d 数组,我的程序编译良好,但不返回任何输出
- 如何在构造函数中使用初始值设定项设置具有相同值的 2d 数组?
- 在 Python 和 c++ 2d 数组初始化之间.这是怎麽?为什么呢?
- 如何打印 2D 字符数组C++
- 如何将数组 2d 作为参数从函数传递并返回数组 2d 此函数
- 数组 2D 多个值
- 创建数组数组 (2D),而无需在 Java 中初始化内部数组
- 如何在C++中将文本文件传输到数组2D
- 从同一类的另一个方法调用数组2D-C++
- 获取地址在数组2d中的位置