| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 565 人关注过本帖
标题:题目为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
快速回复:题目为FatMouse'trade 的一个简单贪心题,测试数据都是对的,但是为什 ...
数据加载中...
 
   



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

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