奇偶排序/砖块排序的C/C++程序

这基本上是 气泡排序 .此算法分为两个阶段-奇数阶段和偶数阶段。该算法一直运行,直到数组元素被排序,并且在每次迭代中出现两个阶段——奇数和偶数阶段。

null

在奇数阶段,我们对奇数索引元素执行气泡排序,在偶数阶段,我们对偶数索引元素执行气泡排序。

// A C++ Program to implement Odd-Even / Brick Sort
#include <bits/stdc++.h>
using namespace std;
// A function to sort the algorithm using Odd Even sort
void oddEvenSort( int arr[], int n)
{
bool isSorted = false ; // Initially array is unsorted
while (!isSorted) {
isSorted = true ;
// Perform Bubble sort on odd indexed element
for ( int i = 1; i <= n - 2; i = i + 2) {
if (arr[i] > arr[i + 1]) {
swap(arr[i], arr[i + 1]);
isSorted = false ;
}
}
// Perform Bubble sort on even indexed element
for ( int i = 0; i <= n - 2; i = i + 2) {
if (arr[i] > arr[i + 1]) {
swap(arr[i], arr[i + 1]);
isSorted = false ;
}
}
}
return ;
}
// A utility function ot print an array of size n
void printArray( int arr[], int n)
{
for ( int i = 0; i < n; i++)
cout << arr[i] << " " ;
cout << "" ;
}
// Driver program to test above functions.
int main()
{
int arr[] = { 34, 2, 10, -9 };
int n = sizeof (arr) / sizeof (arr[0]);
oddEvenSort(arr, n);
printArray(arr, n);
return (0);
}


输出:

-9 2 10 34

请参阅完整的文章 奇偶排序/砖块排序 更多细节!

© 版权声明
THE END
喜欢就支持一下吧
点赞5 分享