当前位置: 首页 > wzjs >正文

html5单页网站模板江北seo页面优化公司

html5单页网站模板,江北seo页面优化公司,龙岩网站设计一般要多久,企业信息化管理平台1. 题意 在一个循环数组中,找到下一个比它大的数。 2. 题解 也不知道怎么就单调栈了,可能是刷出来的吧。。。 还是来解释一下吧!!! 如果有新元素入栈 c c c, 那么在栈内的元素只要小于新元素的 s s s…

1. 题意

在一个循环数组中,找到下一个比它大的数。

2. 题解

也不知道怎么就单调栈了,可能是刷出来的吧。。。

还是来解释一下吧!!!

如果有新元素入栈 c c c

那么在栈内的元素只要小于新元素的 s s s,都需要出栈,因为他们的

下一个更大的元素显然就是 c c c。这些小于 s s s的栈内元素都需要出栈。

更进一步的说,栈内的元素它们都还没有找到下一个更大的元素。

为什么是栈呢?因为我们先比较的是离当前元素最近的,

也就是后入栈的那些先比较,也就满足了先进后出的特性。

那么单调性呢?因为在入栈时需要保证栈内元素是小于当前元素的,因

此栈内元素一定是单调递减的,当然可以相等。

举个例子

6 4 2 5 3 1s:
6  栈空直接入栈
s: 6
4  小于栈顶元素6,直接入栈
s: 6 4
2 小于栈顶元素4, 直接入栈
s:6 4 2
5 大于栈顶元素2, 2 出栈,且它的下一个比它大的元素就是5
s:6 4
5 大于栈顶元素4,4出栈,且它的下一个比它大的元素就是5
s: 6
5 小于栈顶元素6,5入栈
s:6 5
3 小于栈顶元素5,3入栈
s:6 5 3
1 小于栈顶元素3,1入栈
s: 6 5 3 1已经遍历了一遍了,但是栈中还有元素,因此我们又从头遍历6 大于1, 1出栈,且下一个比它大的元素是6
6 大于3, 3出栈,且下一个比它大的元素是6
6 大于5, 5出栈,且下一个比它大的元素是6
6 不大于6, 6入栈
s: 6 6
后面的过程就重复上面的过程了

对于一个循环的数组,我们常常附加一个相同的数组来把它变成

线性的。在这里我们并没有直接附加,而是采取了取模这种方式。

代码其实就没有那么重要了。。。

  • 正向遍历
class Solution {
public:vector<int> nextGreaterElements(vector<int>& nums) {int n = nums.size();        std::stack<int> s;vector<int> ans( n, -1);for (int i = 0; i < 2 * n - 1; ++i) {int idx = i % n;while (!s.empty() && nums[s.top()] < nums[ idx ]) {ans[ s.top() ] = nums[ idx  ];s.pop();}s.push( idx );}return ans;}
};
  • 反向遍历
class Solution {
public:vector<int> nextGreaterElements(vector<int>& nums) {int n = nums.size();        std::stack<int> s;vector<int> ans( n, -1);for (int i = 2 * n - 1; ~i; --i) {int idx = i % n;while (!s.empty( ) && nums[ s.top()] <= nums[ idx ]) {s.pop();}if (!s.empty() && i < n) {ans[ idx ] = nums[s.top()];}s.push( idx );}return ans;}
};
http://www.dtcms.com/wzjs/392532.html

相关文章:

  • 全网站开发是什么口碑营销案例2022
  • 那个网站做毕业设计广州seo搜索
  • 网站建设完成收录查询工具
  • 中国建设银行总行官方网站徐州seo推广优化
  • 长沙做企业网站关键词推广软件
  • 安阳网站建设公司企业推广是做什么的
  • 伊利集团网站建设怎么样呢搜索引擎网络排名
  • 自助建站免费建站五个平台站长
  • 晋江网站建设价格东莞百度快速优化排名
  • 怎么做qq可信任网站自媒体怎么赚钱
  • 微信怎么做链接网站软文营销实施背景
  • 可以在公司局域网做网站吗友情链接怎么互换
  • 淘宝天猫做网站咨询整合营销经典案例
  • 做公司网站详细步骤网推广公司
  • 杨浦区建设小学网站新手怎么做销售
  • 南充网站建设略奥科技推广项目的平台
  • 网站什么时候做解析项目推广计划书
  • wordpress docker安装宁波seo外包服务平台
  • 母婴用品商城网站模板全套下载链接下载
  • 深圳建设交易中心网站应用宝下载
  • 一个电信ip做网站卡不卡网站推广的6个方法是什么
  • 建站知乎如何建一个自己的网站
  • 建设一个有影响力的网站百度山西授权代理
  • wordpress实现前台登录功能天津seo推广优化
  • 在线制作网站系统广州各区风险区域最新动态
  • 免费的logo网站网络优化大师app
  • 网站怎么放到服务器上灰色seo推广
  • 网站公司做网站品牌广告和效果广告的区别
  • 花店网站模板免费下载线下推广方案
  • 深圳专业营销网站制作免费搭建自己的网站