如何用PB写一个快速排序的算法呢?
#include <stdio.h>
#include <stdlib.h>
/*
快速排序算法qsort需要使用到的比较函数,函数地址传入qsort
如果第一个参数指向的数比第二个大,返回1,然后再qsort中发生交换
返回0或-1的情况均不发生数组中的数据交换
*/
int intcmp(const void *pa, const void *pb)
{
int a = *(int*)pa;
int b = *(int*)pb;
return((a > b) ? 1 : ((a == b) ? 0 : -1));/*从小到大排序,若要从大到小,返回条件相反即可 */
}
int
main(void)
{
int i;
int arr[6] = ;
qsort(arr, 6, sizeof(int), intcmp);
for (i = 0; i < 6; ++i)
printf( %d\t , arr[i]);
printf( \n );
system( pause );
return 0;
}
#include <stdlib.h>
/*
快速排序算法qsort需要使用到的比较函数,函数地址传入qsort
如果第一个参数指向的数比第二个大,返回1,然后再qsort中发生交换
返回0或-1的情况均不发生数组中的数据交换
*/
int intcmp(const void *pa, const void *pb)
{
int a = *(int*)pa;
int b = *(int*)pb;
return((a > b) ? 1 : ((a == b) ? 0 : -1));/*从小到大排序,若要从大到小,返回条件相反即可 */
}
int
main(void)
{
int i;
int arr[6] = ;
qsort(arr, 6, sizeof(int), intcmp);
for (i = 0; i < 6; ++i)
printf( %d\t , arr[i]);
printf( \n );
system( pause );
return 0;
}
要看排什么呢。如果是排大小,可以借助学C语言时的气泡法,不过用PB,我觉得可以用datastore 设置排序,速度更快。
把要排序的数据放到datawindow里,然后调用dw的sort()函数。
那要看PB的语法了,首先你应该掌握块拍的思想。
那么就与语言无关了。
那么就与语言无关了。