奇偶排序Linux下c 实现

奇偶排序算法详解及实现
本文详细介绍了奇偶排序算法的核心概念、实现代码及其实现过程,包括奇偶排序头文件、源文件和主文件的代码实现。通过具体实例展示了如何使用奇偶排序对数组进行排序,并提供了实现代码的详细解析。

文章出自http://blog.csdn.net/love__coder/article/details/7914819   

奇偶排序又叫奇偶换位排序,是通过比较数组中相邻位置(奇-偶)的两个元素,如果奇偶对第一个大于第二个,则交换,重复该操作。然后,用类似的方式,依次比对所有偶奇对的元素。下面给出奇偶排序的实现代码:

         1、奇偶排序头文件:oddEvenSort.h

[cpp]  view plain copy
  1. #ifndef ODDEVENSORT_H  
  2. #define ODDEVENSORT_H  
  3. #include<stdbool.h>  
  4. extern void oddEvenSort(int *pArr, const int length);  
  5. #endif  

         2、奇偶排序源文件:oddEvenSort.c

[cpp]  view plain copy
  1. #include "oddEvenSort.h"  
  2. void oddEvenSort(int *pArr, const int length)  
  3. {  
  4.         int i, tmp;  
  5.         bool sorted =false;  
  6.         while(!sorted)  
  7.         {  
  8.                 sorted=true;  
  9.                 for(i=1; i<length-1; i+=2)  
  10.                 {  
  11.                         if(*(pArr+i)>*(pArr+i+1))  
  12.                         {  
  13.                                 sorted=false;  
  14.                                 tmp=*(pArr+i);  
  15.                                 *(pArr+i)=*(pArr+i+1);  
  16.                                 *(pArr+i+1)=tmp;  
  17.                         }  
  18.                 }  
  19.   
  20.                 for(i=0; i<length-1; i+=2)  
  21.                 {  
  22.                         if(*(pArr+i)>*(pArr+i+1))  
  23.                         {  
  24.                                 sorted=false;  
  25.                                 tmp=*(pArr+i);  
  26.                                 *(pArr+i)=*(pArr+i+1);  
  27.                                 *(pArr+i+1)=tmp;  
  28.                         }  
  29.                 }  
  30.         }  
  31. }  

              3、main头文件:main.h

[cpp]  view plain copy
  1. #ifndef MAIN_H  
  2. #define MAIN_H  
  3. #include<stdio.h>  
  4. #include "oddEvenSort.h"  
  5. int main(void);  
  6. void initRandomArr(int *pArr, const int length);  
  7. void showArr(const int *pArr, const int length);  
  8. #endif  

             4、main源文件:main.c

[cpp]  view plain copy
  1. #include "main.h"  
  2. int main(void)  
  3. {  
  4.         int length;  
  5.         printf("Input array length:\n");  
  6.         scanf("%d", &length);  
  7.         if(length < 0)  
  8.         {  
  9.                 printf("Array length must be larger 0\n");  
  10.                 return 1;  
  11.         }  
  12.         int arr[length];  
  13.         initRandomArr(arr, length);  
  14.         printf("Get random array:\n");  
  15.         showArr(arr, length);  
  16.         oddEvenSort(arr, length);  
  17.         printf("oddEventSort result:\n");  
  18.         showArr(arr, length);  
  19.         return 0;  
  20. }  
  21.   
  22. void initRandomArr(int * pArr, const int length)  
  23. {  
  24.         srand(time(NULL));  
  25.         int i;  
  26.         for(i=0; i<length; i++)  
  27.         {  
  28.                 *(pArr+i)=rand()%1000;  
  29.         }  
  30. }  
  31.   
  32. void showArr(const int *pArr, const int length)  
  33. {  
  34.         int i;  
  35.         for(i=0; i< length; i++)  
  36.         {  
  37.                 printf("%d ", *(pArr+i));  
  38.         }  
  39.         printf("\n");  
  40. }  

                5、编译

[cpp]  view plain copy
  1. [root@localhost oddEvenSort]$ gcc -c oddEvenSort.c  
  2. [root@localhost oddEvenSort]$ gcc -c main.c  
  3. [root@localhost oddEvenSort]$ gcc -o main main.o oddEvenSort.o  
           执行可执行文件main如下:

[plain]  view plain copy
  1. [root@localhost oddEvenSort]$ ./main   
  2. Input array length:  
  3. 6  
  4. Get random array:  
  5. 59 967 202 868 171 869   
  6. oddEventSort result:  
  7. 59 171 202 868 869 967   

            奇偶排序最差时间复杂度是O(n²),适用于排序小列表
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值