在C ++中以反向波形打印矩阵

在这个问题上,我们得到一个矩阵。我们的任务是在单行中以反向波形打印矩阵。

这个例子可以使问题更清楚,

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