| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 565 人关注过本帖
标题:题目为FatMouse'trade 的一个简单贪心题,测试数据都是对的,但是为什么一 ...
只看楼主 加入收藏
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
结帖率:86.21%
收藏
已结贴  问题点数:2 回复次数:4 
题目为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
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:2 
看discuss
0 1
1 0
1.000

1 0
0.000

5 4
10000 5
2000 2
100 0
300 0
10400.000


另外不知道楼主用什么编译器.

程序代码:
#include <stdio.h>

int cmp()
{
    return 1.5 - 1.6;
}

int main(int argc, char *argv[])
{
    printf ("result : %d\n", cmp());

    return 0;
}

//gcc-4.8 -Wall -O2 test.c -o test
//result : 0


[fly]存在即是合理[/fly]
2015-10-15 09:57
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
收藏
得分:0 
回复 2楼 azzbcc
我用的是codeblock,编译器是GNU GCC Compiler,然后就是你给的那几个数据,我在本地都通过了,就是在线通不过。。。。也不明白为啥?还请麻烦指导一下。。感激中。。
2015-10-15 18:03
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
我用你的代码,测试数据都不过!

查到的问题是我写的代码,当两者性价比差为 -0.1时,cmp返回 0,没有交换顺序,qsort没能将数组正确排序

你改代码了吧,1L的代码 .food 为0时没有做检查,运行会报错的


[fly]存在即是合理[/fly]
2015-10-16 09:43
境善
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.064414 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved