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

建设银行网站 开户行怎么查傻瓜式大型网站开发工具

建设银行网站 开户行怎么查,傻瓜式大型网站开发工具,No酒类网站建设,网站首页 排版🚀 解法一:哈希表找“连续序列起点” ✅ 思路总结 用 unordered_set 存储所有数字,查找某个数是否存在的时间是 O(1)。 遍历每个数字 x,只从 x 是“连续序列起点”时才开始向右找: 也就是说,只有当 x - 1…

在这里插入图片描述

🚀 解法一:哈希表找“连续序列起点”

✅ 思路总结

  1. unordered_set 存储所有数字,查找某个数是否存在的时间是 O(1)。

  2. 遍历每个数字 x只从 x 是“连续序列起点”时才开始向右找

    • 也就是说,只有当 x - 1 不在集合中时,才从 x 开始数连续的。
  3. x 开始,不断检查 x+1, x+2... 是否存在,一直到找不到为止。

  4. 每次记录最长的连续长度。


✅ C++ 代码

class Solution {
public:int longestConsecutive(vector<int>& nums) {unordered_set<int> st(nums.begin(), nums.end()); // 把所有元素放入哈希集合int ans = 0;for (int x : st) { // 遍历哈希集合中的每个数if (st.contains(x - 1)) {// 如果存在 x-1,说明 x 不是连续序列的起点,跳过continue;}// 否则 x 是连续序列的起点int y = x + 1;while (st.contains(y)) {y++; // 一直向右找连续数字}// [x, y) 之间是连续序列,长度是 y - xans = max(ans, y - x);}return ans;}
};

✅ 示例解释

示例 1:nums = [100, 4, 200, 1, 3, 2]

先构造集合 st = {1, 2, 3, 4, 100, 200}

遍历集合中的每个数:

当前数 x是否起点(x-1不在集合)找到的连续序列序列长度
100[100]1
4否(3在)--
200[200]1
1[1, 2, 3, 4]4
3否(2在)--
2否(1在)--

最终答案就是最长的序列长度 4


✅ 时间 & 空间复杂度分析

  • 时间复杂度

    • 遍历集合:O(n)
    • 每个连续序列最多只遍历一次,即每个元素最多进入一次 while 循环
    • 总体:O(n)
  • 空间复杂度

    • 使用了一个 unordered_set 来存储所有元素 → O(n)

✅ 优点总结

优点说明
✅ 高效时间复杂度 O(n),比排序更快
✅ 简洁逻辑清晰,代码结构简单
✅ 无重复计算通过“只从起点开始”的策略避免重复统计

✅ 通俗一句话总结

把所有数字丢进集合,只从那些“没有左邻居”的数出发,一路数右边的连续数,记录最长的长度!


🚀 解法二:哈希 + 并查集(更适合带区间合并需求的场景)

✅ 思路概括:

我们把每个数字当作并查集中的一个点,如果某个数 xx+1 都存在,就将它们连起来。

最后统计并查集中最长的连通块长度,即为最长连续序列长度。


✅ C++代码

class Solution {
public:unordered_map<int, int> parent;   // 存储每个数的父节点unordered_map<int, int> size;     // 存储以某个节点为根的集合大小(即连续序列长度)// 查找函数:带路径压缩int find(int x) {if (parent[x] != x)parent[x] = find(parent[x]);return parent[x];}// 合并两个集合void unite(int x, int y) {int rootX = find(x);int rootY = find(y);if (rootX == rootY) return;  // 已在同一个集合中// 合并:把小的合并到大的parent[rootX] = rootY;size[rootY] += size[rootX];}int longestConsecutive(vector<int>& nums) {// 初始化并查集for (int x : nums) {if (parent.count(x)) continue; // 避免重复插入重复元素parent[x] = x;size[x] = 1;// 如果相邻的数存在,就合并if (parent.count(x - 1)) unite(x, x - 1);if (parent.count(x + 1)) unite(x, x + 1);}int ans = 0;for (auto& [k, v] : size) {ans = max(ans, v); // 所有集合中找最大值}return ans;}
};

✅ 示例说明

nums = [100, 4, 200, 1, 3, 2] 为例:

  • 插入 100 → 单独成一个集合。
  • 插入 4 → 单独成集合。
  • 插入 200 → 单独成集合。
  • 插入 1 → 单独成集合。
  • 插入 3 → 发现 4 存在 → 合并 3 和 4。
  • 插入 2 → 发现 1 和 3 存在 → 合并 2 和 1,再合并 2 和 3,最终变成 [1,2,3,4] 一个大集合,大小为 4。

✅ 复杂度分析

  • 时间复杂度:近似 O(n)(每次 findunion 的复杂度为 O(α(n)),近似常数)。
  • 空间复杂度:O(n)

✅ 对比第一种解法

比较项解法一:哈希找起点解法二:并查集合并
时间复杂度O(n)O(n)
实现难度⭐⭐(较简单)⭐⭐⭐⭐(中高级)
思路适用范围连续整数序列查找任意需要区间合并


文章转载自:

http://7emmLE5l.rwxtn.cn
http://6YelEzKZ.rwxtn.cn
http://cr1b5ZTD.rwxtn.cn
http://byIO6vLI.rwxtn.cn
http://tceo6F5h.rwxtn.cn
http://H00tnjHr.rwxtn.cn
http://c98v07dW.rwxtn.cn
http://BQT7xT3K.rwxtn.cn
http://KLHSdZpK.rwxtn.cn
http://2PqWiRkJ.rwxtn.cn
http://q7VAfhXm.rwxtn.cn
http://SPUrfhn2.rwxtn.cn
http://FKWcOeYV.rwxtn.cn
http://Epuj4qKJ.rwxtn.cn
http://ycOSeRgy.rwxtn.cn
http://R7lT2wNY.rwxtn.cn
http://bxlPCYux.rwxtn.cn
http://RGPXHTGC.rwxtn.cn
http://9pA8n5Q3.rwxtn.cn
http://yDe7lmCH.rwxtn.cn
http://Mt4LsZcW.rwxtn.cn
http://RBdEPvYX.rwxtn.cn
http://JvuUXWhZ.rwxtn.cn
http://kF5D9kJa.rwxtn.cn
http://jaJXZoh5.rwxtn.cn
http://4udyHtui.rwxtn.cn
http://pWoBjkH5.rwxtn.cn
http://ln5X5on0.rwxtn.cn
http://xScQf4UU.rwxtn.cn
http://hyPKw2QB.rwxtn.cn
http://www.dtcms.com/wzjs/726534.html

相关文章:

  • 网站建设与管理实务整站seo优化一般多少钱
  • 西安城市建设职业学院官方网站网站导航怎么设置
  • 网站建设广金手指六六十四烟台做网站推广的公司哪家好
  • 如何做好企业网站响应式布局概念
  • asp网站开发好怎么预览祥云县住房和城乡建设网站
  • 哪些做网站的公司比较好电子商务前景怎么样
  • 柳江网站开发个人网站酷站赏析
  • 网站建设实习任务完成情况四川省建设安全质量监理协会网站
  • 黄冈商城网站建设哪家好产品开发流程介绍
  • 专业的外贸网站建设公司1分钟视频制作报价明细
  • 做问卷有哪些网站房屋建筑学课程设计图纸
  • 网站正在建设中mp4盐城手机网站制作
  • 专业营销网站费用营销型的物流网站
  • 外贸公司网站搭建网站的建设需要数据库
  • 北京网站制作与建设公司网站建设类的职位
  • 深圳大腕互联网站建设一次备案多个网站
  • 零基础 网站长春移动网站建设
  • 如何申请网站网站内套网站代码
  • 天河做网站服务wordpress $memcached_servers
  • 先看网站案例您的网站也可以这么做天津网站建设招标
  • 网站制作 北京网站建设公司天津南昌网站建设
  • 网站外链建设方法论建设工程施工合同
  • 什么创网站绵阳营销型网站建设
  • 云南大学网站建设西安网站开发工资
  • 网站建设 睿达科网上商城建站服务商
  • 石家庄网站优化招聘海南网络
  • 做古风文字头像的网站书签制作方法图片大全
  • 有经验的网站建设推广wordpress点击图片不显示
  • iis网站怎么做全站伪静态起飞页自助建站平台
  • 文化共享工程网站建设情况单页设计多少钱一张