一个C的小程序
stdlib里有一个qsort函数。快速排序,很方便的。。。很久不用c了,具体用法不太清楚了。。网上搜了下资料:七种qsort排序方法<本文中排序都是采用的从小到大排序>一、对int类型数组排序int num[100]; cmp ( const void *a , const void *b ){return *(int *)a - *(int *)b;}qsort(num,100,sizeof(num[0]),cmp);二、对char类型数组排序(同int类型)char word[100]; cmp( const void *a , const void *b ){return *(char *)a - *(int *)b;}qsort(word,100,sizeof(word[0]),cmp);三、对double类型数组排序(特别要注意)double in[100];int cmp( const void *a , const void *b ){return *(double *)a > *(double *)b ? 1 : -1;}qsort(in,100,sizeof(in[0]),cmp);四、对结构体一级排序struct In{double data;int other;}s[100]//按照data的值从小到大将结构体排序,关于结构体内的排序关键数据data的类型可以很多种,参考上面的例子写int cmp( const void *a ,const void *b){return (*(In *)a)->data > (*(In *)b)->data ? 1 : -1;}qsort(s,100,sizeof(s[0]),cmp);五、对结构体二级排序struct In{int x;int y;}s[100];//按照x从小到大排序,当x相等时按照y从大到小排序int cmp( const void *a , const void *b ){struct In *c = (In *)a;struct In *d = (In *)b;if(c->x != d->x) return c->x - d->x;else return d->y - c->y;}qsort(s,100,sizeof(s[0]),cmp);六、对字符串进行排序struct In{int data;char str[100];}s[100];//按照结构体中字符串str的字典顺序排序int cmp ( const void *a , const void *b ){return strcmp( (*(In *)a)->str , (*(In *)b)->str );}qsort(s,100,sizeof(s[0]),cmp);七、计算几何中求凸包的cmpint cmp(const void *a,const void *b) //重点cmp函数,把除了1点外的所有点,旋转角度排序{struct point *c=(point *)a;struct point *d=(point *)b;if( calc(*c,*d,p[1]) < 0) return 1;else if( !calc(*c,*d,p[1]) && dis(c->x,c->y,p[1]。
x,p[1]。y) < dis(d->x,d->y,p[1]。x,p[1]。y)) //如果在一条直线上,则把远的放在前面return 1;else return -1;}PS:其中的qsort函数包含在<stdlib。
h>的头文件里,strcmp包含在<string。h>的头文件里。
找个排序算法用用就可以了。网上搜一下一箩筐
4个值得用排序算法么?
偶的是C++的 不过估计也可以# include <iostream>using namespace std;int main(){ int a[n],j,i,temp; for(i=0;i<n;i++) cin>>a[i]; for(i=0;i<n;i++) for(j=i+1;j<n;j++) {if (a[i]>a[j] ) {temp=a[i]; a[i]=a[j]; a[j]=temp;} }; return 0;} n 是可以取任意整数的 参考资料:自己编的
答:您可以按住菜单键进行建立。详情>>
问:网络的进网络的进电脑买起了。该选择网络了。 他们说宽带(就拿艾普来说)比电信AD...
答:1.5M=0.5M ?没听说过,我就知道我家的2M=230KB,都说很正常,你还打算玩什么样的大型游戏?营业厅的给你说的天花乱坠,你问问给你装宽带的,根本不是那...详情>>