【LeetCode面试题17.04】消失的数字

【LeetCode面试题17.04】消失的数字

刷爆LeetCode系列

LeetCode面试题17.04:消失的数字

github地址

有梦想的电信狗

前言

本文用C++三种方法实现LeetCode面试题17.04:消失的数字

  • 方法一:数组哈希
  • 方法二:数学求和再相减
  • 方法三:位运算

题目描述

题目链接https://leetcode.cn/problems/missing-number-lcci/description/

在这里插入图片描述

题目与思路分析

目标分析

  1. 数组nums包含从0n的所有整数,但其中缺了一个。编写代码找出那个缺失的数字
  2. 要求时间复杂度至多为O(n)

思路一:数组哈希

思想

  • 题目给出一个长度为 n 的数组,元素取值范围为 0 ~ n,且恰好缺失一个数
  • 新建一个长度为 n + 1 的辅助数组 v,下标表示数字本身,值表示是否出现过。
  • 遍历原数组,将出现过的数字对应位置标记为 1
  • 再遍历辅助数组,第一个为 0 的下标就是缺失的数字

注意事项

  • 辅助数组长度必须是 nums.size() + 1,否则无法覆盖 n
  • 访问 v[nums[i]] 前要保证 nums[i] 一定在 0 ~ n 范围内。
  • 时间复杂度为 O(n),空间复杂度为 O(n)

思路二:数学求和

思想

  • 如果 0 ~ n 没有缺失,总和应为:
    t o t a l = n ( n + 1 ) 2 total = \frac{n(n+1)}{2} total=2n(n+1)​
  • 实际数组的元素之和记为 sum
  • 由于只缺失一个数,那么
    m i s s i n g = S − s u m missing = S - sum missing=S−sum
  • 一次遍历即可算出答案。

注意事项

  • n = nums.size(),而不是数组中最大值。
  • 使用 int 时要注意是否可能溢出(本题数据范围安全)。
  • 时间复杂度 O(n),空间复杂度 O(1)

思路三:位运算(异或)

思想

  • 异或的性质:
    • a ^ a = 0
    • a ^ 0 = a
  • 数组中包含 0 ~ n 缺一个数,共 n 个数。
  • 将数组中所有元素互相异或,再将 0 ~ n 全部互相异或:
    • 出现两次的数字会互相抵消为 0
    • 只出现一次的那个数字(缺失值)会被保留下来
  • 最终的异或结果就是缺失的数。

注意事项

  • 第二个循环必须遍历 0 ~ n(即 i <= nums.size())。
  • 异或不会产生溢出问题,适合大范围整数。
  • 时间复杂度 O(n),空间复杂度 O(1)

代码实现

思路一:数组哈希

// 数组哈希classSolution{public:intmissingNumber(vector<int>& nums){// 0-n 共 n+1 个数,缺了一个,还剩 n 个// 开一个大小为n+1 的数组,初始化值均为0// 遍历 这n个数,将其对应下标的位置标记为 1// 再遍历这个数组,值为0的位置的下标,就是缺失的数 vector<int>v(nums.size()+1,0);for(auto e:nums){ v[e]=1;}int i =0;for(;i< v.size();++i){if(v[i]==0)break;}return i;}};

思路二:数学求和

// 求和classSolution{public:intmissingNumber(vector<int>& nums){// 0-n 这些数 正确的和 为 totalint total = nums.size()*(nums.size()+1)/2;int sum =0;// 缺了一个数后的和 为 sumfor(auto e:nums) sum += e;return total - sum;// 相差的值 即为 缺失的数字}};

思路三:位运算

// 位运算classSolution{public:intmissingNumber(vector<int>& nums){// 数组中有 0-n 缺了一个,共 n 个数,再在后面添加 0 - n 这完全不缺 的 n + 1 个数// 则共有 2n+1 个数 2n+1个数中,消失的数只出现了一次// 其他数,每个数都出现了两次// 一个数 和0 异或 等于它本身 一个数 和 它本身异或 等于 0int res =0;for(int i =0;i<nums.size();++i) res ^= nums[i];for(int i =0;i<=nums.size();++i) res ^= i;return res;}};

算法代码优化

  • 可以选择使用STL自带的哈希容器优化,但非必须
  • 其他方法无需优化
classSolution{public:intmissingNumber(vector<int>& nums){ unordered_set<int> set;// 将这 n 个数 插入到 哈希setfor(auto e : nums){ set.insert(e);}int missing =-1;// 再遍历数字 0-n 那个数字没有出现,就是缺失的数字for(int i =0; i <= nums.size(); i++){if(set.count(i)==0){ missing = i;break;}}return missing;}};

结语

以上就是本文的所有内容了,如果觉得文章对你有帮助,欢迎 点赞⭐收藏 支持!如有疑问或建议,请在评论区留言交流,我们一起进步

分享到此结束啦
一键三连,好运连连!
你的每一次互动,都是对作者最大的鼓励!征程尚未结束,让我们在广阔的世界里继续前行! 🚀

Read more

【大模型系列篇】大模型基建工程:基于 FastAPI 自动构建 SSE MCP 服务器

【大模型系列篇】大模型基建工程:基于 FastAPI 自动构建 SSE MCP 服务器

今天我们将使用FastAPI来构建 MCP 服务器,Anthropic 推出的这个MCP 协议,目的是让 AI 代理和你的应用程序之间的对话变得更顺畅、更清晰。FastAPI 基于 Starlette 和 Uvicorn,采用异步编程模型,可轻松处理高并发请求,尤其适合 MCP 场景下大模型与外部系统的实时交互需求,其性能接近 Node.js 和 Go,在数据库查询、文件操作等 I/O 密集型任务中表现卓越。 开始今天的正题前,我们来回顾下相关的知识内容: 《高性能Python Web服务部署架构解析》、《使用Python开发MCP Server及Inspector工具调试》、《构建智能体MCP客户端:完成大模型与MCP服务端能力集成与最小闭环验证》   FastAPI基础知识 安装依赖 pip install uvicorn, fastapi FastAPI服务代码示例  from fastapi import FastAPI app

By Ne0inhk
超详细图文教程:用vscode+copilot(代理模式)便捷使用mcp+一个范例:用自然语言进行3d建模

超详细图文教程:用vscode+copilot(代理模式)便捷使用mcp+一个范例:用自然语言进行3d建模

在vscode使用claude mcp吧! 在vscode更新到最新版本(注意,这是前提)后,内置的copilot可以使用mcp了!!! 关于mcp(Model Context Protocol 模型上下文协议),可以参考我的上一篇文章: MCP个人理解+示例+集成管理+在python中调用示例,给AI大模型装上双手-ZEEKLOG博客 以下是使用教程: 1.点击左下角的齿轮状设置按钮,点击设置 2.在输入面板输入chat.agent.enabled,勾上勾选框 3.点击Ctrl+shift+P,输入reload,点击重新加载窗口,刷新窗口 4.打开copilot后,在右下角将模式改为代理即可。 5.点击工具按钮,开始安装mcp 先去github找到自己想要添加的mcp服务,以blender MCP为例,打开https://github.com/ahujasid/blender-mcp,可以在readme文档里看到详细的安装过程。可以看到,

By Ne0inhk
02-mcp-server案例分享-Excel 表格秒变可视化图表 HTML 报告,就这么简单

02-mcp-server案例分享-Excel 表格秒变可视化图表 HTML 报告,就这么简单

1.前言 MCP Server(模型上下文协议服务器)是一种基于模型上下文协议(Model Context Protocol,简称MCP)构建的轻量级服务程序,旨在实现大型语言模型(LLM)与外部资源之间的高效、安全连接。MCP协议由Anthropic公司于2024年11月开源,其核心目标是解决AI应用中数据分散、接口不统一等问题,为开发者提供标准化的接口,使AI模型能够灵活访问本地资源和远程服务,从而提升AI助手的响应质量和工作效率。 MCP Server 的架构与工作原理 MCP Server 采用客户端-服务器(Client-Server)架构,其中客户端(MCP Client)负责与服务器建立连接,发起请求,而服务器端则处理请求并返回响应。这种架构确保了数据交互的高效性与安全性。例如,客户端可以向服务器发送请求,如“查询数据库中的某个记录”或“调用某个API”,而服务器则根据请求类型,调用相应的资源或工具,完成任务并返回结果。 MCP Server 支持动态发现和实时更新机制。例如,当新的资源或工具被添加到服务器时,

By Ne0inhk
将现有 REST API 转换为 MCP Server工具 -higress

将现有 REST API 转换为 MCP Server工具 -higress

Higress 是一款云原生 API 网关,集成了流量网关、微服务网关、安全网关和 AI 网关的功能。 它基于 Istio 和 Envoy 开发,支持使用 Go/Rust/JS 等语言编写 Wasm 插件。 提供了数十个通用插件和开箱即用的控制台。 Higress AI 网关支持多种 AI 服务提供商,如 OpenAI、DeepSeek、通义千问等,并具备令牌限流、消费者鉴权、WAF 防护、语义缓存等功能。 MCP Server 插件配置 higress 功能说明 * mcp-server 插件基于 Model Context Protocol (MCP),专为 AI 助手设计,

By Ne0inhk