码迷,mamicode.com
首页 > 其他好文 > 详细

[NOIP2011]观光公交 题解

时间:2016-10-29 18:31:11      阅读:240      评论:0      收藏:0      [点我收藏+]

标签:print   div   read   style   ast   etc   i++   span   站点   

题目大意:

  就省了吧

思路:

  应该算是贪心。

  不难发现,加速只对所有在使用加速器之后连续的一段下车时不用等人的站点下车的人有用。这非常重要。

  先算出不加速时的和,并预处理出每个站点最迟到的人的时间、每个站下车的人数。然后一个一个放加速器,加速器放在惠及最多的人的一段,同时维护到每个站点的时间(判断用不用等人)。

代码:

 1 #include<cstdio>
 2 #include<iostream>
 3 using namespace std;
 4 const int M=100005,N=1005;
 5 int n,m,k,i,j,mx,ans,t[M],off[M],last[M],come[M],down[M],dist[N];
 6 
 7 int read()
 8 {
 9     int x=0;
10     char ch=getchar();
11     while (ch<0 || ch>9) ch=getchar();
12     while (ch>=0 && ch<=9) x=(x<<1)+(x<<3)+ch-48,ch=getchar();
13     return x;
14 }
15 
16 int main()
17 {
18     n=read(),m=read(),k=read();
19     for (i=1;i<n;i++) dist[i]=read();
20     for (i=1;i<=m;i++) t[i]=read(),last[j=read()]=max(last[j],t[i]),off[down[i]=read()]++;
21     for (i=1;i<n;i++) come[i+1]=max(come[i],last[i])+dist[i];
22     for (i=1;i<=m;i++) ans+=come[down[i]]-t[i];
23     while (k--)
24     {
25         for (i=1;i<=n;i++) t[i]=0;
26         for (i=1;i<n;i++)
27             if (dist[i])
28                 for (j=i+1;j<=n;j++)
29                 {
30                     t[i]+=off[j];
31                     if (come[j]<=last[j]) break;
32                 }
33         mx=0;
34         for (i=1;i<n;i++)
35             if (t[i]>mx) mx=t[i],j=i;
36         dist[j]--,ans-=t[j],come[++j]--;
37         for (;j<n;j++) come[j+1]=max(come[j],last[j])+dist[j];
38     }
39     printf("%d\n",ans);
40     return 0;
41 }

 

[NOIP2011]观光公交 题解

标签:print   div   read   style   ast   etc   i++   span   站点   

原文地址:http://www.cnblogs.com/HHshy/p/6011171.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!