Chinaunix首页 | 论坛 | 博客
  • 博客访问: 200825
  • 博文数量: 67
  • 博客积分: 2970
  • 博客等级: 少校
  • 技术积分: 685
  • 用 户 组: 普通用户
  • 注册时间: 2010-07-23 11:36
文章分类

全部博文(67)

文章存档

2012年(2)

2011年(19)

2010年(46)

我的朋友

分类: C/C++

2010-09-20 16:25:27



#include<stdio.h>
#include<algorithm>

const int MAX=10005;

struct Node
{
    int p,d;
};
Node node[MAX];
int pre[MAX];

int find(int x)    //返回1…x天区间中最后一个可用天的编号,若没有可用则返回-1

{
    if(x<=0) return -1;  //不存在可用天
    if(pre[x]==x)   //存在最接近期限的可用天
    {
        pre[x]--;
        return pre[x];    
    }
    pre[x]=find(pre[x]);  //这段被占据的区间中每一天都指向最近的可用天
    return pre[x];
}

int cmp(const void *a,const void *b)
{
    return (*(Node*)b).p-(*(Node*)a).p;
}

int main()
{
    int n;
    while(scanf("%d",&n)!=EOF)
    {
        int max=0;
        for(int i=0;i<n;i++)
        {
            scanf("%d%d",&node[i].p,&node[i].d);
            if(node[i].d>max) max=node[i].d;
        }
        for(int i=0;i<=max;i++) pre[i]=i;        
        qsort(node,n,sizeof(Node),cmp);
        int sum=0;
        for(int i=0;i<n;i++) if(find(node[i].d)!=-1) sum+=node[i].p;
        printf("%d\n",sum);
    }
    return 0;
}


总结:
首先进行预处理,让获利大的产品先卖,并尽量占据最接近期限的可用天。每一天i指向最接近i的可用天,
因而初始pre[i]=i,当位于接近期限i的可用天被占用后pre[i]--,即指向下一个能被期限i可用的天的编号,当下
一个可用天是另一个期限时,就要考虑合并这两个期限的可用天,即让这两个期限分享最接近这两个期限
的可用天,依次类推,直至没有空闲天可用。
阅读(1530) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~