国外电商网站新人怎么自己做网站

张小明 2026/3/12 15:17:14
国外电商网站,新人怎么自己做网站,手机网站设计字体大小,手机网站效果图做多大的#x1f4dd; 前言今天在刷 LeetCode 热题 100 时#xff0c;碰到了第 128 题 “最长连续序列”。这是一道非常经典的题目#xff0c;考察的重点是如何在不排序的情况下#xff0c;利用哈希表在 O(n) 的时间复杂度内完成查找。乍一看这道题如果用 Arrays.sort() 排序后遍历… 前言今天在刷 LeetCode 热题 100 时碰到了第 128 题“最长连续序列”。这是一道非常经典的题目考察的重点是如何在不排序的情况下利用哈希表在 O(n) 的时间复杂度内完成查找。乍一看这道题如果用Arrays.sort()排序后遍历时间复杂度是 O(nlog n)但这道题明确要求O(n)所以必须换一种思路。记录一下我的解题心得和最终代码。 题目描述给定一个未排序的整数数组nums找出数字连续的最长序列不要求序列元素在原数组中连续的长度。示例 1输入 nums [100,4,200,1,3,2]输出 4解释 最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。提示请设计并实现时间复杂度为 O(n) 的算法。 解题思路1. 为什么不能排序题目硬性要求时间复杂度为 O(n)。我们知道标准的排序算法如快排、归并最快也是 O(nlog n)所以排序这条路走不通。我们需要一种能够快速查找的数据结构哈希表 (HashSet)是最佳选择。2. 核心逻辑去重与定位“起点”我们可以分两步走去重与存储先把所有数字放入HashSet中这样我们不仅去除了重复元素还能在 O(1) 的时间内判断一个数是否存在。寻找序列起点如果我们对集合中的每一个数x都去尝试向后枚举 (x1,x2...)时间复杂度最坏会达到 O(n^2)。关键优化点我们只从序列的起点开始查找。如何判断起点如果一个数x它的前驱x-1不在集合中那么x一定是某个连续序列的第一个数。只有当x是起点时我们才开始向后匹配x1,x2等等统计长度。3. 一个小优化在统计过程中如果当前找到的最长序列长度已经超过了哈希表中剩余元素的一半或者总数的一半其实就可以提前结束循环了因为剩下的元素数量不可能凑出更长的序列。 代码实现 (Java)代码相比官方题解做了变量名的语义化修改使其更符合工程规范方便阅读。class Solution { public int longestConsecutive(int[] nums) { // 1. 预处理将数组元素放入 HashSet实现去重和 O(1) 查询 SetInteger numSet new HashSet(); for (int num : nums) { numSet.add(num); } int maxLen 0; int totalNums numSet.size(); // 2. 遍历集合中的每个元素 for (int num : numSet) { // 核心剪枝逻辑 // 只有当 num-1 不存在时num 才是一个连续序列的【起点】 // 如果 num-1 存在说明 num 已经被计算过了直接跳过 if (!numSet.contains(num - 1)) { int currentNum num; int currentLen 1; // 从起点开始不断向后寻找连续的数字 while (numSet.contains(currentNum 1)) { currentNum 1; currentLen 1; } // 更新最大长度 maxLen Math.max(maxLen, currentLen); // 【可选优化】如果当前找到的长度已经超过总数的一半 // 那么剩下的元素不可能组成更长的序列直接退出 if (maxLen totalNums / 2) { break; } } } return maxLen; } } 复杂度分析时间复杂度O(n)虽然代码里有一个while循环嵌套在for循环里但仔细分析会发现由于if (!numSet.contains(num - 1))的限制数组中的每个数最多只会被访问两次一次是作为序列起点被访问一次是作为序列的一部分被内部while访问。因此总的操作次数是线性的。空间复杂度O(n)我们需要一个HashSet来存储数组中的元素以空间换时间。 总结这道题是哈希表运用的典范。解决很多 O(n) 复杂度问题的秘诀往往就在于“如何避免重复计算”。在这道题里通过判断x-1是否存在精准地锁定了每个序列的头部从而避免了大量的无效枚举。
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

建设一个公司网站要具备什么自我介绍ppt配图

第一章:适配Open-AutoGLM总失败?问题根源全解析在集成 Open-AutoGLM 框架时,许多开发者频繁遭遇适配失败的问题。这些问题往往并非源于框架本身缺陷,而是由环境配置、依赖版本不匹配或初始化逻辑错误导致。常见错误类型与排查路径…

张小明 2026/3/5 6:18:40 网站建设

网站策划书案例做h5的网站

Wan2.2-T2V-A14B:当AI开始“拍电影”,你的开发工具选对了吗? 在影视制作行业,曾经一部短片的诞生需要编剧、导演、摄影、剪辑等多个角色协作数周甚至数月。而今天,只需一句自然语言描述——“一位穿着汉服的女孩在樱花…

张小明 2026/3/5 6:18:42 网站建设

福州制作手机网站施工企业安全生产评价表

初学者最痛苦的问题: “我明明在函数里把 head 改了,为什么外面没变?” 答案就是:你只改了“副本”。 1)先用一句话说清:C 默认都是值传递 void f(int x){ x 10; }外面变量不会变,因为 x 是拷贝…

张小明 2026/3/5 6:18:43 网站建设

网站建设文案模板湛江网站模板

Python Web开发:Flask与Django实战指南 1. Flask与Twitter API集成 在Web开发中,Flask是一个强大的Python框架,可用于快速构建动态网站。下面我们将展示如何使用Flask与Twitter API集成,获取用户的推文。 首先,我们需要设置请求参数: tweetRequestParams = {“oauth…

张小明 2026/3/5 6:18:44 网站建设

给做网站建设的一些建议如何保存wordpress主题设置

Linly-Talker在婚姻登记处的政策咨询服务应用 在各地婚姻登记处的办事大厅里,总能看到这样的场景:一对新人或离异夫妻站在服务窗口前,反复询问“再婚需要什么材料?”“离婚冷静期怎么算?”,而工作人员一边翻…

张小明 2026/3/5 6:18:44 网站建设

接平面设计私活的网站网页设计师证书考试时间

Stream-rec多平台直播自动录制工具完整使用指南 【免费下载链接】stream-rec Automatic streaming record tool powered by FFmpeg. 虎牙/抖音/斗鱼/Twitch/PandaTV直播,弹幕自动录制 项目地址: https://gitcode.com/gh_mirrors/st/stream-rec 项目概述 Str…

张小明 2026/3/5 6:18:46 网站建设