Leetcode1—两数之和C++实现

该博客详细介绍了如何使用C++解决LeetCode上的第一道题,即寻找数组中两个数的和等于目标值的下标。通过创建一个临时数组并排序,然后使用双指针从两端向中间遍历,找到匹配的数并返回它们的下标。代码清晰,逻辑简洁,适合初学者学习和理解算法应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Leetcode1—两数之和C++实现

题目:给定一个数组,和一个目标值target,遍历数组中的元素,找到两个元素之和恰好等于target,返回两个元素的下标。
输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。

解题思路:

设置两个空vector,一个将原数组中的元素全部拷贝过来,进行遍历查找,其中采用双指针的方法:指针i指向首元素,指针j指向尾元素,找到两个元素和等于target之后,将这两个元素存到空的vector中返回。

具体实现:

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
vector<int> Twosum(vector<int>& arr, int target)
{
	vector<int>ans;
	vector<int>temp;
	temp = arr;
	int n = temp.size();
	sort(temp.begin(),temp.end());
	int i = 0; int j = n - 1;
	while (i < j)
	{
		int sum = temp[i] + temp[j];
		if (sum > target)
			j--;
		else if (sum < target)
			i++;
		else break;
	}
	if (i < j)
	{
		for (int k = 0; k < n; k++)
		{
			if (i<n &&arr[k] == temp[i])//这里是个讲究,顺序不能颠倒
			{
				ans.push_back(k);
				i = n;
			}
			else if (j<n &&arr[k] == temp[j] )
			{
				ans.push_back(k);
				j = n;
			}
			if (i == n && j == n)
				return ans;
		}
	}
	return ans;
}
int main()
{
	vector<int>arr = { 1,9,7,8,5,4,6,3,2 };
	vector<int>temp=Twosum(arr, 10);
	for (vector<int>::iterator it=temp.begin();it!=temp.end();it++)
	{
		cout << *it << " ";
	}
	cout << endl;
}

输出如下:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值