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

【LeetCode力扣热题100】【LeetCode 1】两数之和

方法一:暴力循环

两层循环,遍历所有的组合,直到满足条件,返回结果。

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {for(int i=0; i<nums.size()-1 ;i++){for(int j = i+1; j<nums.size(); j++){if(nums[i]+nums[j] == target)return {i, j};}}return {};}
};

方法二:哈希表

循环遍历一次,用map存储遍历过的元素和索引,元素为map的key,索引为map的value。每次遍历时在map中查找等于【target - nums[i]】的key,找到则返回答案,未找到则将元素和索引存入map。

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {map<int, int> numsmap;for(int i=0; i<nums.size() ;i++){if(numsmap.find(target - nums[i]) != numsmap.end()){return {i, numsmap[target - nums[i]]};}numsmap[nums[i]] = i;}return {};}
};

注:map和unordered_map的区别

std::map

  • 内部实现std::map通常是基于红黑树(一种自平衡二叉搜索树)实现的。这意味着元素会按照键排序,并且保证了所有操作(插入、删除、查找)的时间复杂度为O(log n)。
  • 查找开销:由于它是一个有序的数据结构,所以查找一个元素需要进行树的遍历,平均时间复杂度为O(log n)。
  • 插入/删除开销:同样地,插入或删除一个元素也需要O(log n)的时间,因为可能需要重新平衡树以保持其性质。
  • 内存使用:通常比std::unordered_map占用更多内存,因为每个节点除了存储数据外还需要存储额外的指针用于维持树结构。
  • 有序性std::map中的元素是按键的顺序排列的,这对于需要有序访问的应用场景非常有用。

std::unordered_map

  • 内部实现std::unordered_map基于哈希表实现,元素之间没有固定的顺序。它通过哈希函数将键映射到桶中,从而提供平均情况下的常数时间复杂度O(1)的操作。
  • 查找开销:在理想情况下(即没有哈希冲突),查找操作的时间复杂度为O(1),但在最坏的情况下(例如当所有元素都映射到了同一个桶时),查找时间可能会退化到O(n)。
  • 插入/删除开销:同样地,在没有哈希冲突的情况下,插入和删除的时间复杂度也是O(1)。然而,随着哈希冲突的增加,性能也会下降。
  • 内存使用:一般而言,std::unordered_map相比std::map更节省空间,因为它不需要维护树结构所需的额外指针。
  • 无序性std::unordered_map中的元素不是按任何特定顺序排列的,因此如果你的应用程序依赖于按键排序,则不适合使用这个容器。
http://www.lryc.cn/news/501485.html

相关文章:

  • 定制链接类名,两类跳转传参,vue路由重定向,404,模式设置
  • 【ArcGIS微课1000例】0135:自动生成标识码(长度不变,前面自动加0)
  • ISO45001职业健康安全管理体系认证流程
  • VueRouter路由
  • 性能测试攻略(一):需求分析
  • 【24年新算法时间序列预测】黑翅鸢BKA优化Transformer时间序列预测(评估指标全,出图多)
  • YOLOv8改进,YOLOv8引入CARAFE轻量级通用上采样算子,助力模型涨点
  • ZooKeeper节点扩容
  • 深度学习的unfold操作
  • C# 抽奖程序winform示例
  • 嵌入式蓝桥杯学习9 usart串口
  • 车载ADB:让汽车更智能的桥梁
  • HarmonyOS-高级(一)
  • 【优选算法-滑动窗口】长度最小的子数组、无重复字符的最长子串、最大连续1的个数、将x减为0的最小操作数、水果成篮
  • Leetcode 每日一题 202.快乐数
  • SEC_ASA 第一天作业
  • Fluss:面向实时分析设计的下一代流存储
  • 【一本通】质因数分解
  • vue2+html2canvas+js PDF实现试卷导出和打印功能
  • 【Python网络爬虫 常见问题汇总】
  • Java SpringBoot 项目怎样在 IDEA 中运行、部署
  • GAMES101:现代计算机图形学-笔记-10
  • 【前端面试】Http篇
  • ZZCMS2023存在跨站脚本漏洞(CNVD-2024-44822、CVE-2024-44818)
  • Android 15 前台服务类型的变更
  • 微信小程序开发简易教程
  • 树莓派 发那科 Fanuc Linux跨平台CNC数控数据采集协议,TCP协议包
  • Ubuntu中安装配置交叉编译工具并进行测试
  • C++核心day3作业
  • socket UDP 环路回显的服务端