可以采用冒泡排序的方法。以下给题主一个对既定数组进行升序、降序排序的代码
#include <
stdio.h>
#include <time.h>
#define elemType int /*元素类型*/
#define LEN 100 /*数组长度上限*/
#define ASC 0 /*升序*/
#define DESC 1 /*降序*/
/*冒泡排序*/
/*参数说明:*/
/*elemType arr[]:排序目标数组*/
/*int len:元素个数*/
/*int order:排序方式;升序(由小到大):ASC;降序(由大到小):DESC*/
void bubbleSort (elemType arr[], int len, int order) {
int i, j, temp;
for (i = 0; i < len - 1; i++)
for (j = 0; j < len - 1 - i; j++) {
if (order == ASC) { /*升序*/
if (arr[j] > arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
else if (order == DESC) { /*降序*/
if (arr[j] < arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
/*打印数组*/
void printArr (elemType arr[], int len) {
int i;
for (i=0; i<len; i++)
printf ("%d\t",arr[i]);
putchar ('\n');
}
int main (void) {
elemType arr[LEN] = {3,5,1,7,2,9,6,8,10,4};
int len;
len = 10;
puts ("初始数组:");
printArr (arr,len);
putchar ('\n');
puts ("升序排列:");
bubbleSort (arr, len, ASC); /*升序冒泡排序*/
printArr (arr,len);
putchar ('\n');
puts ("降序排列:");
bubbleSort (arr, len, DESC); /*降序冒泡排序*/
printArr (arr,len);
putchar ('\n');
getch (); /*屏幕暂留*/
return 0;
}
运行结果