poj 2153解题报告

tle了n次后,经过波波的指导,成功的ac了这道小水题.写篇报告记录一下~~

这道题的难点是字符串的匹配.通过用二分匹配法可以在规定的时间内对已排序的数组进行查找.这应该是对qsort和bsearch应用的一种训练.而我觉得题目本身就对储存结构有比较明显的提示.

  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>
  4. //数据储存
  5. typedef struct data
  6. {
  7.     char names[35];
  8.     int point;
  9. }data;
  10. // 用于qsort和bsearch的比较函数
  11. int compare(const void *p1,const void *p2)
  12. {
  13.     data a=*(data *)p1;
  14.     data b=*(data *)p2;
  15.     if( strcmp(a.names,b.names) > 0)
  16.         return 1;
  17.     if( !strcmp(a.names,b.names))
  18.         return 0;
  19.     return -1;
  20. }
  21. //找出liming的位置
  22. int findPosition(data* D,int size,int mPosition)
  23. {
  24.     int temp = D[mPosition].point ,res = 1;
  25.     forint i = 0; i < size; i++)
  26.         if( D[i].point > temp)
  27.             res++;
  28.     return res;
  29. }
  30. int main()
  31. {
  32.     data *Data;
  33.     int i,j,n,m,posiMing;
  34.     scanf("%d/n",&n);
  35.     Data = new ( data[n]);
  36.     for( i = 0; i < n;i++) {
  37.         gets(Data[i].names);
  38.         Data[i].point = 0;
  39.     }
  40.     qsort(Data,n,sizeof(data),compare);
  41.     forint i = 0; i < n;i++)
  42.         if(!strcmp(Data[i].names ,"Li Ming")) {
  43.             posiMing = i;
  44.             break;
  45.         }
  46.     scanf("%d/n",&m);
  47.     for( i = 0; i < m; i++) {
  48.         data *position,temp ;
  49.         for( j = 0; j < n; j++) {
  50.             scanf("%d ",&temp.point);
  51.             gets(temp.names);
  52.             // 找出与名字相匹配的元素的位置
  53.             position = (data*) bsearch(&temp,Data,n,sizeof(data),compare);
  54.             position->point += temp.point;
  55.         }
  56.         printf("%d/n",findPosition(Data,n,posiMing));
  57.     }
  58. }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值