news 2026/4/23 15:41:29

滑窗+hash|pii dfs

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
滑窗+hash|pii dfs

lc2423

// try -- every char

一个变量控制不明白 那就再加一个变量🤓👆🏻

++cnt; // restore

class Solution {

public:

bool equalFrequency(string word)

{

unordered_map<char,int> hash;

for(auto& c:word)

hash[c]++;

// try -- every char

for(auto& [ch, cnt] : hash)

{

--cnt;

bool f=true;

int t = 0; //freq

for(auto& [k, v] : hash)

{

if(v == 0) continue;

if(t == 0) t = v; // init

if(v != t)

{

f=false;

break;

}

}

if(f) return true;

++cnt; // restore

}

return false;

}

};

lc549

pii dfs遍历二叉树

记录每个节点“递增连续长度up”和“递减连续长度down”

计算以该节点为中心的最长连续序列长度

最终得到整棵树的最长连续序列

"递"获取每个node pii

"归"的时候return以该节点为中间的最长链

class Solution {

public:

int ans = 0;

int longestConsecutive(TreeNode* root) {

auto dfs = [&](this auto&& dfs, TreeNode* node) -> pair<int, int> {

if (!node) return {0, 0};

auto [lu, ld] = dfs(node->left);

auto [ru, rd] = dfs(node->right);

int u = 1, d = 1;

if (node->left && node->val == node->left->val + 1) u = max(u, lu + 1);

if (node->right && node->val == node->right->val + 1) u = max(u, ru + 1);

//record two path choice mx

if (node->left && node->val == node->left->val - 1) d = max(d, ld + 1);

if (node->right && node->val == node->right->val - 1) d = max(d, rd + 1);

ans = max(ans, u + d - 1);

return {u, d};

};

dfs(root);

return ans;

}

};

lc3641

滑窗和hash天生一对😋

class Solution {
//set size
//max len
public:
int longestSubarray(vector<int>& nums, int k)
{
int n=nums.size();
unordered_map<int,int> hash;
int l=0,r=0,mx=0,rp=0;
while(r<n)
{
if(++hash[nums[r]]==2)
rp++;
r++;
while(rp>k)
{
if(--hash[nums[l]]==1)
rp--;
l++;
}
mx=max(mx,r-l);
}
return mx;
}
};

rust导入hash

use std::collections::HashMap;

impl Solution {
pub fn longest_subarray(nums: Vec<i32>, k: i32) -> i32 {
let n = nums.len();
let mut hash = HashMap::new();
let mut l = 0;
let mut rp = 0;
let mut mx = 0;

for r in 0..n {
let cnt =hash.entry(nums[r]).and_modify(|c| *c += 1).or_insert(1);
if *cnt == 2 {
rp += 1;
}

while rp > k {
let cnt = hash.entry(nums[l]).and_modify(|c| *c -= 1).or_insert(0);
if *cnt == 1 {
rp -= 1;
}
l += 1;
}

mx = mx.max((r - l + 1) as i32);
}

mx
}
}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 9:46:58

安全运维工程师和传统运维工程师在工作内容上有什么主要区别?

安全运维工程师和传统运维工程师虽然都带着“运维”二字&#xff0c;工作环境也常有交集&#xff0c;但他们的核心目标、日常工作重心和所需的技能图谱有着本质的区别。为了让你能快速把握全局&#xff0c;下表清晰地展示了它们在四个核心维度上的不同。对比维度传统运维工程师…

作者头像 李华
网站建设 2026/4/23 9:47:15

sync.Pool 真不是“对象池”:Go GC 性能优化的隐藏王牌

sync.Pool 深度解析本期分享 sync.Pool&#xff1a;短生命周期对象的复用技巧&#xff0c;以及它在 Go Runtime 与 GC 背后发生的那些事。一、为什么需要 sync.Pool 要理解 为什么会有 sync.Pool&#xff0c;我们需要先理解 Heap Allocation&#xff08;堆分配&#xff09;。 1…

作者头像 李华
网站建设 2026/4/23 9:48:20

实时对抗类游戏AI难训练?破解高动态环境下的3大技术瓶颈

第一章&#xff1a;实时对抗类游戏AI训练的挑战与机遇实时对抗类游戏为人工智能提供了极具挑战性的测试平台。这类环境不仅要求AI具备快速决策能力&#xff0c;还需在信息不完全、对手策略动态变化的情况下持续适应。由于每局对战的时间步长极短&#xff0c;且动作空间庞大&…

作者头像 李华
网站建设 2026/4/23 11:14:21

CDMA在移动通信系统中的应用研究与仿真

一、CDMA技术原理及在移动通信中的核心优势 CDMA&#xff08;码分多址&#xff09;是基于扩频通信技术的多址接入方式&#xff0c;其核心原理是通过不同的伪随机码&#xff08;PN码&#xff09;区分用户信号&#xff0c;实现多用户在同一频率和时间资源上的并行通信。在发送端&…

作者头像 李华
网站建设 2026/4/23 14:36:46

【值得收藏】大模型实战教程:从基础原理到企业应用,零门槛掌握AI开发

本文全面介绍大模型技术&#xff0c;涵盖AI概念、应用场景、企业落地方法、技术原理与架构及本地部署。强调大模型是提升企业效率的工具&#xff0c;通过业务流程解构可找到落地场景。同时指出大模型存在的短板和多种技术架构选择&#xff0c;为读者提供从理论到实践的完整学习…

作者头像 李华