爱问知识人 爱问教育 医院库

一个C的小程序

首页

一个C的小程序


        

提交回答
好评回答
  • 2005-11-26 22:27:00
      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>的头文件里。

    夏***

    2005-11-26 22:27:00

其他答案

    2005-11-27 11:41:00
  • 找个排序算法用用就可以了。网上搜一下一箩筐

    w***

    2005-11-27 11:41:00

  • 2005-11-27 10:31:00
  • 4个值得用排序算法么?

    哎***

    2005-11-27 10:31:00

  • 2005-11-27 08:48:00
  • 偶的是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 是可以取任意整数的                     参考资料:自己编的

    y***

    2005-11-27 08:48:00

  • 互联网 相关知识

  • 电脑网络技术
  • 电脑网络

相关推荐

正在加载...
最新资料 推荐信息 热门专题 热点推荐
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200

热点检索

  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200
返回
顶部
帮助 意见
反馈

确定举报此问题

举报原因(必选):