zoukankan      html  css  js  c++  java
  • LuoguP1016 旅行家的预算 (贪心)

    胡一个错误代码都能有75pts
    忘了怎么手写deque其实是懒

    #include <cstdio>
    #include <iostream>
    #include <cstring>
    #include <algorithm>
    #include <cmath>
    #define R(a,b,c) for(register int a = (b); (a) <= (c); ++(a))
    #define nR(a,b,c) for(register int a = (b); (a) >= (c); --(a))
    #define Fill(a,b) memset(a, b, sizeof(a))
    #define Max(a,b) ((a) > (b) ? (a) : (b))
    #define Min(a,b) ((a) < (b) ? (a) : (b))
    #define Swap(a,b) ((a) ^= (b) ^= (a) ^= (b))
    
    //#define ON_DEBUGG
    
    #ifdef ON_DEBUGG
    
    #define D_e_Line printf("
    ----------
    ") 
    #define D_e(x) cout << (#x) << " : " << x << endl
    #define Pause() system("pause")
    #define FileOpen() freopen("in.txt", "r", stdin)
    
    #else
    
    #define D_e_Line ;
    #define D_e(x) ;
    #define Pause() ;
    #define FileOpen() ;
    
    #endif
    using namespace std;
    struct ios{
    	template<typename ATP>inline ios& operator >> (ATP &x){
    		x = 0; int f = 1; char ch;
    		for(ch = getchar(); ch < '0' || ch > '9'; ch = getchar()) if(ch == '-') f = -1;
    		while(ch >= '0' && ch <= '9') x = x * 10 + (ch ^ '0'), ch = getchar();
    		x *= f;
    		return *this;
    	}
    }io;
    
    template<typename ATP>inline ATP max(ATP &a, ATP &b){
    	return a > b ? a : b;
    }
    #include <deque>
    
    struct Petrol {
        double cost, volume;
    };
    
    deque<Petrol> dq;
    double dis[17], price[17];
    
    int main() {
    FileOpen();
    
    	double totDis, fuelMax, dx;
    	int n;
        scanf("%lf%lf%lf%lf%d", &totDis, &fuelMax, &dx, &price[0], &n);
        R(i,1,n){
            scanf("%lf%lf", &dis[i], &price[i]);
            if(dis[i] - dis[i - 1] > fuelMax * dx){
                printf("No Solution
    ");
                return 0;
            }
        }
        
        dis[n+1] = totDis;
        double fuelNow = fuelMax;
        dq.push_back((Petrol){price[0], fuelMax});
        double ans = price[0] * fuelMax;
        R(i,1,i + 1){
            double costFuel = (dis[i] - dis[i - 1]) / dx;
            while(!dq.empty() && costFuel > 0){
                Petrol x = dq.front(); dq.pop_front();
                if(x.volume > costFuel){
                    fuelNow -= costFuel;
                    dq.push_front((Petrol){x.cost, x.volume - costFuel});
                    break;
                }
                fuelNow -= x.volume;
    			costFuel -= x.volume;
            }
            
            if(i == n + 1){
                while(!dq.empty()) {
                    ans -= dq.front().cost * dq.front().volume;
                    dq.pop_front();
                }
                break;
            }
            
            while(!dq.empty() && dq.back().cost > price[i]){
                ans -= dq.back().cost * dq.back().volume;
                fuelNow -= dq.back().volume;
                dq.pop_back();
            }
            
            ans += (fuelMax - fuelNow) * price[i];
            dq.push_back((Petrol){price[i], fuelMax - fuelNow});
            fuelNow = fuelMax;
        }
        
        printf("%.2lf
    ", ans);
        return 0;
    }
    
  • 相关阅读:
    Linux 多线程环境下 进程线程终止函数小结
    C++:vector中的resize()函数 VS reserve()函数
    Linux进程间通信之信号量(semaphore)、消息队列(Message Queue)和共享内存(Share Memory)
    Linux进程间通信之管道(pipe)、命名管道(FIFO)与信号(Signal)
    求全与求专
    wpf \silverlight 保存控件为图片
    软件版本号详解(转)
    WPF 自定义快捷键命令(Command)(转)
    WIN2003系统远程桌面多连接数设置终极大法
    程序集强命名与GAC
  • 原文地址:https://www.cnblogs.com/bingoyes/p/11437418.html
Copyright © 2011-2022 走看看