当前位置: 首页 > 网络知识

[BZOJ1029] [JSOI2007]建筑抢修(贪心 + 优先队列)

时间:2026-01-29 09:28:05

传送门

把数据存在结构体中,至于怎么贪心?

肯定会有些想法,正确错误先不必说,先来试一试。

1.按照 t2 为第一关键字从小到大排,按照 t1 为第二关键字从小到大排

  这个显然错,比如后面有个数的 t1 比前面小,t2 比前面大,显然用这个代替前面的更优

2.按照 t1 为第一关键字从小到大排,按照 t2 为第二关键字从小到大排

  这个也是错的,比如

  4

  1 1

  1 5

  3 4

  4 5

  按照这个贪心是 2,实际应该是 3

至于正确贪心,如果 当前时间 + t1[i] <= t2[i],说明可以建完,ans++,并把 t1 放入大根堆

       如果 当前时间 + t1[i] > t2[i],说明不能建,那么把当前的 t1[i] 和堆顶比较

         如果 > 堆顶,continue

         如果 < 堆顶,如果 当前时间 堆顶 + t1[i] <= t2[i],说明拿它替换堆顶更优,那么就替换,ans++

1 #include <cstdio> 2 #include <queue> 3 #include <algorithm> 4 5 int n, time, ans; 6 struct node 7 p[150001]; 10 std::priority_queue <int> q; 11 12 inline bool cmp(node x, node y) 13 16 17 int main() 18 31 else if(p[i].a < q.top()) 32 39 } 40 } 41 printf("%d", ans); 42 return 0; 43 }
View Code

我真是菜啊,错误的贪心都举不出来反例,只有对拍出来。



上一篇:[luoguP3390]【模板】矩阵快速幂
下一篇:分块来水题
stl 贪心
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素