dfs|bfs|定长栈|栈+双指针

lc1574

用栈可以维护单增序列,但是怎么样去找这个删除的最短子序列呢

  • 找最长前缀非递减序列、最长后缀非递减序列
  • 再用双指针找二者最优拼接点(因为想最小可能的删除,所以存在双指针的单调性)

class Solution {

public:

int findLengthOfShortestSubarray(vector<int>& arr) {

int n = arr.size();

if (n <= 1) return 0;

// 步骤1:找最长前缀非递减序列的结束位置left

int left = 0;

while (left + 1 < n && arr[left] <= arr[left + 1]) {

left++;

}

if (left == n - 1) return 0; // 整个数组已非递减

// 步骤2:找最长后缀非递减序列的起始位置right

int right = n - 1;

while (right - 1 >= 0 && arr[right - 1] <= arr[right]) {

right--;

}

// 步骤3:初始候选答案(只保留前缀或只保留后缀的情况)

int ret = min(n - left - 1, right);

// 步骤4:双指针找前缀和后缀的最优拼接点

int i = 0, j = right;

while (i <= left && j < n) {

++if (arr[i] <= arr[j]) {
// 可以拼接,更新答案
ret = min(ret, j - i - 1);
++

i++;

} ++else
j++;
++

}

return ret;

}

};

lc1673

定长栈

+剩余数的条件三判断 保障了k长

while (!st.empty() && x < st.back() && st.size() + nums.size() - i > k) st.pop_back();

class Solution {

public:

vector<int> mostCompetitive(vector<int>& nums, int k) {

vector<int> st;

for (int i = 0; i < nums.size(); i++) {

int x = nums[i];

while (!st.empty() && x < st.back() && ++st.size() + nums.size() - i > k) {
st.pop_back();
++

}

++if (st.size() < k)
st.push_back(x);
++

}

return st;

}

};

lc865

(DFS)计算节点深度

若左右子树深度相同,当前节点即为最深叶子的最近公共祖先(LCA);

否则取深度更深的子树的LCA

pair<TreeNode*,int> dfs(TreeNode* root,int depth)

亮点:pair dfs

出口!

auto left记录下一层拿到的结果,再去进行return if-else比较,确定return what

class Solution {

public:

TreeNode* subtreeWithAllDeepest(TreeNode* root){

return dfs(root,0).first;

}

//还和深度有关 维护一个pair

pair<TreeNode*,int> dfs(TreeNode* root,int depth)

{

//出口 空节点

if(!root)

return {nullptr,depth-1};

auto left=dfs(root->left,depth+1);

//1 catch return left

auto right=dfs(root->right,depth+1);

//返回控制

if(!root->left && !root->right)

return {root,depth};

// 比较左右子树深度

++if(left.second == right.second)++

++return {root, left.second};++

++//++2 battle = return root,dep

else if(left.second > right.second)

return left;

//3 !=已完成 继承return longer

else

return right;

}

};

lcr44

class Solution {

public:

vector<int> largestValues(TreeNode* root)

{

if(!root) return {};

vector<int> ret;

queue<TreeNode*> q;

q.push(root);

while(q.size())

{

int sz=q.size();

int mx=INT_MIN;

while(sz--)

{

auto t=q.front();

q.pop();

mx=max(mx,t->val);

if(t->left)

q.push(t->left);

if(t->right)

q.push(t->right);

}

ret.push_back(mx);

}

return ret;

}

};

相关推荐
深邃-20 分钟前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
We་ct3 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程7 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮8 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说8 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove9 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung9 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了9 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL9 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰10 小时前
C++ 排列组合完整指南
开发语言·c++·算法