[栈] leetcode 456 132 Pattern

problem:https://leetcode.com/problems/132-pattern/

        昨晚睡觉前想了一下,今早写好后交了一下居然过了。

        我的想法是维护用一个数据结构来维护到目前为止出现的“13”pattern,为了减少计算量,把一些可能的“13”pattern合并,比如对于一个递增的数组:

        2,3,4,5,6

        合并后的“13”pattern就是 “26”。

        对于以上数组,下一个数字只可能有这几种情况:

        (1) 比最大的数<6>还大 —> 直接和pattern合并

        (2) 处在最小数<2>和最小数<6>之间 —> 找到了答案

        (3) 等于最大数<6>或最小数<2> —> 无事发生,继续执行

        (4) 小于最小数<2>,当前pattern不再改变,把该数作为新的pattern的最小值来维护

        对于每个新出现的数字,都在目前已有的"13"pattern中查询,它是否满足大于pattern"1",并且小于pattern"3",如果满足,就返回true。

        总之,就是一个不断维护和查询的过程。

        由于查询的复杂度和pattern数组的长度有关,所以不能算是O(N)算法,速度只打败了30%多,感觉应该有优化空间。(主要原因应该是,用如下的方法可能会维护冗余的pattern)

class Solution {
public:
    vector<int> sta;
    bool find132pattern(vector<int>& nums) {
        for (int i = 0; i < nums.size(); i++)
        {
            if (sta.empty())
            {
                sta.push_back(nums[i]);
            }
            else
            {
                // check valid
                for (int k = 1; k < sta.size(); k += 2)
                {
                    if (nums[i] > sta[k - 1] && nums[i] < sta[k])
                    {
                        return true;
                    }
                }
                // even number, find the first number
                if (sta.size() % 2 == 0)
                {
                    if (nums[i] > sta.back())
                    {
                        sta.pop_back();
                        sta.push_back(nums[i]);
                    }
                    else if(nums[i] < sta[sta.size() - 2])
                    {
                        sta.push_back(nums[i]);
                    }
                }

                // odd number, find the second number
                else
                {
                    if (nums[i] > sta.back())
                    {
                        sta.push_back(nums[i]);
                    }
                    else
                    {
                        sta.pop_back();
                        sta.push_back(nums[i]);
                    }
                }
            }

        }
        return false;
    }
};

 

转载于:https://www.cnblogs.com/fish1996/p/11262973.html

引用\[1\]提供了一个朴素的解法,使用两个来存储字符串,一个用来存储普通字符,另一个用来存储特殊字符。遍历字符串,如果是普通字符则压入第一个,如果是特殊字符则弹出第一个顶元素。最后比较两个是否相同即可判断字符串是否有效。这个解法的时间复杂度是O(M + N),空间复杂度也是O(M + N)。\[1\] 引用\[2\]提供了另一个的应用场景,即判断括号是否有效。遍历字符串,如果是左括号则压入,如果是右括号则判断和顶元素是否匹配,不匹配则返回false,匹配则弹出顶元素。最后判断是否为空即可判断括号是否有效。\[2\] 引用\[3\]也提供了一个判断括号是否有效的解法,使用来操作。遍历字符串,如果是左括号则压入,如果是右括号则判断和顶元素是否匹配,不匹配则返回false,匹配则弹出顶元素。最后判断是否为空即可判断括号是否有效。这个解法使用了HashMap来存储括号的对应关系。\[3\] 综上所述,在解决字符串相关问题中有着广泛的应用,包括判断字符串是否有效、逆波兰表达式等。在解决这些问题时,可以帮助我们保存和处理字符的顺序,从而简化问题的处理过程。 #### 引用[.reference_title] - *1* *3* [Leetcode刷题03-](https://blog.csdn.net/weixin_47802917/article/details/123007699)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v4^insert_chatgpt"}} ] [.reference_item] - *2* [leetCode-类型详解](https://blog.csdn.net/zhiyikeji/article/details/125508011)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v4^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值