免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1436 | 回复: 0
打印 上一主题 下一主题

qsort函数问题? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-03-12 00:36 |只看该作者 |倒序浏览
  1. #include<stdio.h>
  2. #include<string.h>
  3. #include<stdlib.h>

  4. int num[100];
  5. char name[100][10];
  6. int mark[100];
  7. int tag[100];

  8. int n1,n2;
  9. int comp(const void *a,const void *b);//比较函数

  10. main()
  11. {
  12.    
  13. int i,k=0;
  14. while(scanf("%d%d",&n1,&n2)&&n1)
  15. {     for(i=0;i<n1;i++)             //循环输入数据
  16.      {
  17.         scanf("%d%s%d",&num[i],name[i],&mark[i]);
  18.         tag[i]=i;
  19.      }
  20.      qsort(tag,n1,sizeof(int),comp);//根据comp函数来排序tag数组
  21.      printf("Case %d:\n",++k);
  22.      for(i=0;i<n1;i++)
  23.         printf("%06d %s %d\n",num[tag[i]],name[tag[i]],mark[tag[i]]);//根据tag排序结果输出数组相应值
  24. }

  25. }
  26. int comp(const void *a,const void *b)
  27. {int *x=(int*)a;  //将a,b强制成整形指针
  28. int *y=(int*)b;
  29. int c,d;
  30. c=x-(int *)tag;//计算指针到数组开始位置的距离
  31. d=y-(int *)tag;

  32.     if(n2==2)//从这里开始应用得到的距离c,d进行相应比较
  33.     {
  34.         if(strcmp(name[c],name[d])!=0)
  35.             return(strcmp(name[c],name[d]));

  36.     }
  37.     else if(n2==3)
  38.     {   
  39.         if(mark[c]!=mark[d])   
  40.             return (mark[c]-mark[d]);
  41.     }
  42.     return num[c]-num[d];
  43. }
  44. 这是一道acm题
  45. 输入:
  46. 3 1            //第一行的意思是总共有3行数据输入,按第1列排序,如果输入为3 2,则
  47. 000007 James 85        //按第2列排序,如果第2列有重复数据,则按第1排序
  48. 000010 Amy 90        
  49. 000001 Zoe 60


  50. 结果:
  51. Case 1:
  52. 000001 Zoe 60
  53. 000007 James 85
  54. 000010 Amy 90

  55. 是不是comp强制转换问题啊,当按第2,3列排序是总是出错
  56. 请各位给看看
  57. 谢谢
复制代码

题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1862

[ 本帖最后由 我是害虫 于 2008-3-12 00:41 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP