qq_33876383 2016-11-16 07:40 采纳率: 0%
浏览 1027

杭电1009 测试数据都对还是WA 新入ACM坑求解答啊:(


#include <iostream>
#include <iomanip>
#include<algorithm>
#define MAX 1000
using namespace std;
struct room{
    int javabeen;
    int catfood;
    double price;
};
room a[MAX];
int M,N,n0,n1;
bool rule(room x,room y){
    return x.price<y.price;
}
int main(){
    while(cin>>M>>N && !(M==-1 && N==-1)){
        for(int i=0;i<N;i++){
            cin>>n0>>n1;
            a[i].javabeen=n0;
            a[i].catfood=n1;
            if(n0==0) a[i].price=-1; 
            a[i].price=(double)n1/n0; 
        }
        sort(a,a+N,rule);
            double get=0.0;
            for(int i=0;i<N;i++){
                if(a[i].price==-1) break;
                if(M>=a[i].catfood){
                    M-=a[i].catfood;
                    get+=a[i].javabeen;
                }
                else{
                    get=get+(double)M/a[i].price;
                    M=0;
                    break;
                }
            }
            cout<<fixed<<setprecision(3)<<get<<endl;
    }
    system ("pause");
    return 0;
}

  • 写回答

2条回答 默认 最新

  • threenewbee 2016-11-16 16:28
    关注
    评论

报告相同问题?

悬赏问题

  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料