在这个问题上,我们得到一个矩阵。我们的任务是在单行中以反向波形打印矩阵。
这个例子可以使问题更清楚,
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