【2023】字节跳动 10 日心动计划——第三关

目录

  • [1. 最长有效括号](#1. 最长有效括号)
  • [2. 有序数组的平方](#2. 有序数组的平方)

1. 最长有效括号

🔗 原题链接:32. 最长有效括号

类似于有效的括号,考虑用栈来解决。

具体来讲,我们始终保持栈底元素为当前已经遍历过的元素中「最后一个没有被匹配的右括号的下标」,这样的做法主要是考虑了边界条件的处理,栈里其他元素维护左括号的下标。

从左往右遍历整个字符串,如果遇到 (,则将其下标压入栈中;如果遇到 ),则 弹出栈顶元素,然后判断栈是否为空,如果栈为空,说明当前的右括号为没有被匹配的右括号,将其压入栈中,否则,更新答案。

注意,任何时刻,只有栈底元素是右括号的下标,其他元素都是左括号的下标!

cpp 复制代码
class Solution {
public:
    int longestValidParentheses(string s) {
        stack<int> stk;
        int ans = 0;
        stk.push(-1);

        for (int i = 0; i < s.size(); i++) {
            if (s[i] == '(') stk.push(i);
            else {
                stk.pop();
                if (stk.empty()) stk.push(i);
                else ans = max(ans, i - stk.top());
            }
        }

        return ans;
    }
};

2. 有序数组的平方

🔗 原题链接:977. 有序数组的平方

这里介绍两种做法。

方法一:找到正负元素的分界线,然后对正、负数组进行二路归并。

cpp 复制代码
class Solution {
public:
    vector<int> sortedSquares(vector<int>& nums) {
        int p = lower_bound(nums.begin(), nums.end(), 0) - nums.begin();
        int i = p, j = p - 1;
        vector<int> res;

        while (i < nums.size() && j >= 0) {
            int a = pow(nums[i], 2), b = pow(nums[j], 2);
            if (a <= b) res.push_back(a), i++;
            else res.push_back(b), j--;
        }

        while (i < nums.size()) {
            int a = pow(nums[i], 2);
            res.push_back(a);
            i++;
        }

        while (j >= 0) {
            int b = pow(nums[j], 2);
            res.push_back(b);
            j--;
        }

        return res;
    }
};

方法二:同样使用双指针。之前我们是让两个指针从中间往两边移动,这次我们让两个指针从两边往中间移动,所以填答案的时候需要倒着填。

cpp 复制代码
class Solution {
public:
    vector<int> sortedSquares(vector<int>& nums) {
        int n = nums.size();
        vector<int> res(n);
        int i = 0, j = n - 1, k = n - 1;

        while (i <= j) {
            int a = nums[i] * nums[i];
            int b = nums[j] * nums[j];
            if (a >= b) res[k] = a, i++;
            else res[k] = b, j--;
            k--;
        }

        return res;
    }
};
相关推荐
python_tty34 分钟前
排序算法(二):插入排序
算法·排序算法
然我42 分钟前
面试官:如何判断元素是否出现过?我:三种哈希方法任你选
前端·javascript·算法
risc1234561 小时前
BKD 树(Block KD-Tree)Lucene
java·数据结构·lucene
F_D_Z1 小时前
【EM算法】三硬币模型
算法·机器学习·概率论·em算法·极大似然估计
kk_stoper1 小时前
如何通过API查询实时能源期货价格
java·开发语言·javascript·数据结构·python·能源
秋说1 小时前
【PTA数据结构 | C语言版】字符串插入操作(不限长)
c语言·数据结构·算法
凌肖战2 小时前
力扣网编程135题:分发糖果(贪心算法)
算法·leetcode
Tony沈哲3 小时前
OpenCV 图像调色优化实录:从 forEach 到并行 + LUT 提速之路
opencv·算法
遇见尚硅谷4 小时前
C语言:20250714笔记
c语言·开发语言·数据结构·笔记·算法
Norvyn_74 小时前
LeetCode|Day11|557. 反转字符串中的单词 III|Python刷题笔记
笔记·python·leetcode