hdu 3233 Download Manager(模擬題)

(2009 Asia Wuhan Regional Contest Hosted by Wuhan University)

題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid=3233

題意:給出一些文件需要下載,現在給出了文件的大小和已經下載的百分比,按照一定的下載順序,求最後下載所有文件所需要的時間。下載的規則是:優先下載較小的文件,如果有大小相同的文件,優先已下載百分比較多的文件。

分析:按照優先規則排序,然後可以維護一個長度爲m的數組,記錄該文件剩餘的字節,每次一定是字節最少的文件行下載完累加所需時間,然後更新剩餘正在下載的m-1個文件的字節,直到所有文件都下載完,最後累加時間即爲輸出結果。

參考代碼:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;

const double eps = 1e-7;

struct node{
    node(){}
    node(double _size,double _rem):size(_size),rem(_rem){}
    double size,rem;
};

node Q[1005],data[20005];

bool cmp(node a,node b)
{
    if(fabs(a.size-b.size) < eps) return a.rem > b.rem;
    return a.size < b.size;
}

double solve(int n,int m,double b)
{
    int len = 0;
    double ans = 0;
    for(int i = 0;i < n;++i)
    {
        if(len < m)
        {
            double Size = data[i].size*(1-data[i].rem*0.01);
            if(fabs(Size) < eps) continue;
            Q[len++] = node(Size,0.0);
            for(int j = len-1;j > 0;--j)
            {
                if(Q[j].size < Q[j-1].size)
                swap(Q[j],Q[j-1]);
                else
                break;
            }
        }
        if(len == m)
        {
            double t = Q[0].size / (b / m),s = Q[0].size;
            ans += t;
            for(int j = 1;j < len;++j)
            {
                Q[j].size -= s;
                Q[j-1] = Q[j];
            }
            len--;
        }
    }
    for(int i = 0;i < len;++i)
    {
        double t = Q[i].size / (b / (len-i)),s = Q[i].size;
        ans += t;
        for(int j = i;j < len;++j)
        Q[j].size -= s;
    }
    return ans;
}

int main()
{
    int n,m,b,casenum = 1;
    while(scanf("%d%d%d",&n,&m,&b) && n+m+b)
    {
        for(int i = 0;i < n;++i)
        scanf("%lf%lf",&data[i].size,&data[i].rem);
        sort(data,data+n,cmp);
        printf("Case %d: %.2lf\n\n",casenum++,solve(n,m,(double)b));
    }
    return 0;
}


發佈了74 篇原創文章 · 獲贊 33 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章