单调栈单调队列.pptxVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
单调栈单调队列

单调栈 单调队列 By 苏赞文 看一个简单问题 求一串数的最长不降子序列的个数。 如:1 3 6 2 7 5 8 9 ans:6 维护一个单调不减栈~ 例题:Largest Rectangle in a Histogram(POJ2559) 给定一串长度为n(n = 100000)的序列hi(hi = 10^9),可以画出其直方图,问其中面积最大的矩形是多大? 如 n = 7, 序列为2 1 4 5 1 3 3 思想 朴素的做法,复杂度最坏为O(n^2) 对于一个数a[i]来说,如何找到向左和向右能扩 展到的位置? 两种实现方法,模拟下~ 核心代码一: 栈扫描(单调栈),复杂度接近O(n) long long ans = 0; int top = 0; list[n] = 0; stack[top] = list[0]; idx[top++] = 0; for(int i=1;i=n;i++) { if(stack[top-1] list[i]) { while(top 0 stack[top-1] list[i]) { long long tmp = (long long)(i - idx[top-1]) * stack[top-1]; if(tmp ans) { ans = tmp; } top--; } stack[top++] = list[i]; } else { stack[top] = list[i]; idx[top++] = i; } } printf(%lld\n,ans); 核心代码二: 将高度从高到低排序,用并查集维护当前集合的宽度(节点个数),取max(当前高度 * 宽度)为答案。复杂度为O(nlogn + na(n)) h[n + 1] = h[0] = -1; for(i = 1; i = n; i++) l[i] = r[i] = i; for(i = 1; i = n; i++) while (h[l[i] - 1] = h[i]) l[i] = l[l[i] - 1]; for(i = n; i = 1; i--) while (h[r[i] + 1] = h[i]) r[i] = r[r[i] + 1]; 作业: POJ 2559 3494 2796 2082 (差不多一样的) POJ 2452(思想难) 例题:Second My Problem First(hdu 3706) Give you three integers n(1 = n = 107),A and B(1 = A, B = 231-1) Define Si = Ai mod B and Ti = Min{ Sk | i-A = k = I k = 1} . Calculate the product of Ti (1 = i = n) mod B. 核心代码: long long tmp = 1,res = 1; int head = 0,rear = -1; for(int i=1;i=n;i++) { tmp *= a; tmp %= b; while(rear = head Q[rear] = tmp) { rear--; } Q[++rear] = tmp; idx[rear] = i; while(idx[head] i - a) { head++; } res = (res * Q[head]) % b; } printf(%lld\n,res); POJ 2823 Thanks~

文档评论(0)

精品报告 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档