用 C++ 转换数组为锯齿状


在本教程中,我们将讨论将数组转换成锯齿状的程序。

为此,我们将得到一个包含不同元素的数组。我们的任务是用与前一个元素交替出现的方式,重新排列给定数组的元素,其中元素大小交替出现。

示例

 在线演示

#include <iostream>
using namespace std;
//converting into zig-zag fashion
void convert_zigzag(int arr[], int n) {
   //flag denotes the greater or smaller relation
   bool flag = true;
   for (int i=0; i<=n-2; i++) {
      if (flag) {
         if (arr[i] > arr[i+1])
         swap(arr[i], arr[i+1]);
      } else {
         if (arr[i] < arr[i+1])
            swap(arr[i], arr[i+1]);
      }
      flag = !flag;
   }
}
int main() {
   int arr[] = {4, 3, 7, 8, 6, 2, 1};
   int n = sizeof(arr)/sizeof(arr[0]);
   convert_zigzag(arr, n);
   for (int i=0; i<n; i++)
      cout << arr[i] << " ";
   return 0;
}

输出

3 7 4 8 2 6 1

更新于:2020-01-16

301 浏览

启动你的 职业生涯

通过完成课程来获得认证

开始
广告
© . All rights reserved.