标题:题目为FatMouse'trade 的一个简单贪心题,测试数据都是对的,但是为什么一 ...
取消只看楼主
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
结帖率:86.21%
已结贴  问题点数:2 回复次数:2 
题目为FatMouse'trade 的一个简单贪心题,测试数据都是对的,但是为什么一直ac不了?麻烦大神们看看啊~~
#include<stdio.h>
#include <stdlib.h>
struct s{
  double javabean;
  double food;
  double price;//性价比
}s[1000];

//快排函数
int cmp(const void* a,const void* b){
   return ((struct s*)b)->price-((struct s*)a)->price;
}
int main(){
    double m;
    int n,i;
    double result=0;
  while(scanf("%lf%d",&m,&n)!=EOF){
      if(m==-1&&n==-1) break;//最后一组数据
      for(i=0;i<n;i++){
        scanf("%lf%lf",&s[i].javabean,&s[i].food);
        s[i].price=s[i].javabean/s[i].food;
        //printf("%.f  %.f  %.3f",s[i].javabean,s[i].food,s[i].price);
          }//输入数据

    qsort(s,n,sizeof(s[0]),cmp);//按性价比从大到小进行排序
    /*for(i=0;i<n;i++){
        printf("%.f  %d  %.3f\n",s[i].javabean,s[i].food,s[i].price);
    }*/
    result=0;
    for(i=0;i<n;i++){
        if(s[i].food<=m){
            result+=s[i].javabean;
            m-=s[i].food;
        }else if(s[i].food>m&&m>0){
         result+=s[i].price*m;
         m=0;
        }//if-else
    }//for
    printf("%.3lf\n",result);
  }//while
  return 0;
}
搜索更多相关主题的帖子: include double return result 性价比 
2015-10-14 17:31
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
得分:0 
回复 2楼 azzbcc
我用的是codeblock,编译器是GNU GCC Compiler,然后就是你给的那几个数据,我在本地都通过了,就是在线通不过。。。。也不明白为啥?还请麻烦指导一下。。感激中。。
2015-10-15 18:03
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
得分:0 
回复 4楼 azzbcc
请看  我运行的结果。。
2015-10-16 10:26



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-458190-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.802677 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved