在这个问题上,我们得到一个矩阵。我们的任务是在单行中以反向波形打印矩阵。
这个例子可以使问题更清楚,
Input: 1 4 6 11 2 5 8 54 7 9 3 43 1 7 4 34 Output: 11 54 43 34 4 3 8 6 4 5 9 7 1 7 2 1
为了解决这个问题,我们必须打印矩阵的反向波形,为此,我们将向下打印最后一列的元素,然后向上打印最后一列的元素,依此类推。数组。
显示我们解决方案实施情况的程序
#include<iostream> using namespace std; #define R 4 #define C 4 void printReverseWaveForm(int m, int n, int arr[R][C]) { int i, j = n - 1, wave = 1; while (j >= 0) { if (wave == 1) { for (i = 0; i < m; i++) cout<<arr[i][j]<<" "; wave = 0; j--; } else { for (i = m - 1; i >= 0; i--) cout<<arr[i][j]<<" "; wave = 1; j--; } } } int main() { int arr[R][C] = { { 1, 5, 7, 98 }, { 15, 22, 45, 12 }, { 5, 10, 21, 34 }, { 31, 24, 45, 60 } }; cout<<"Reverse Wave Form of the given matrix :\n"; printReverseWaveForm(R, C, arr); return 0; }
输出结果
给定矩阵的反向波形-
98 12 34 60 45 21 45 7 5 22 10 24 31 5 15 1