力扣第1题:两数之和(C++)

方法一:双层循环暴力求解

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        int n=nums.size();
        for(int i=0;i<n;i++){
            for(int j=i+1;j<n;j++){
                if(nums[i]+nums[j]==target){
                    return {i,j};// 如果相等,则返回这两个索引组成的向量
                }
            }
        }
        return {};//找不到就返回空向量
    }
};

方法二:哈希表

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int, int> indices;//创建哈希表<数值,索引>
        for (int i = 0; i < nums.size(); i++) {
            int v = nums[i];
            int prevV = target - v;
            if (indices.count(prevV)) {// 检查 prevV 是否在哈希表中存在
                return {i, indices[prevV]};
            }
            indices[v] = i;// 如果没有找到匹配,将当前元素和它的索引存入哈希表
        }
        
        return {};
    }
};
相关推荐
祝大家百事可乐6 分钟前
嵌入式——02 数据结构
c++·c#·硬件工程
Yu_Lijing8 分钟前
基于C++的《Head First设计模式》笔记——生成器模式
c++·笔记·设计模式
A923A12 分钟前
【洛谷刷题 | 第四天】
算法·前缀和·贪心·洛谷·差分
bai_lan_ya24 分钟前
使用linux的io文件操作综合实验_处理表格
linux·服务器·算法
计算机安禾28 分钟前
【C语言程序设计】第36篇:二进制文件的读写
c语言·开发语言·c++·算法·github·visual studio code·visual studio
ZPC821029 分钟前
OLOv11 + 深度相机的方案实现高精度3D定位
人工智能·数码相机·算法·机器人
_日拱一卒34 分钟前
LeetCode:字母异位词分组
算法·leetcode·职场和发展
Dfreedom.35 分钟前
机器学习经典算法全景解析与演进脉络(监督学习篇)
人工智能·学习·算法·机器学习·监督学习
2301_8073671943 分钟前
C++代码风格检查工具
开发语言·c++·算法
Morwit43 分钟前
*【力扣hot100】 215. 数组中的第K个最大元素
数据结构·c++·算法·leetcode·职场和发展