LeetCode之两数之和

1. 题目

  给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。示例:给定 nums = [2, 7, 11, 15], target = 9因为 nums[0] + nums[1] = 2 + 7 = 9所以返回 [0, 1]

2.代码

  • 核心思想
  1. 没啥好解释的!!!!!

1. 暴力法

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

2. 两遍哈希表

  • 函数
  1. map函数的类型是pair类型。 (关键字, 角标) map<int, int> a 表示的是定义

  2. map函数插入方法
    方法一:利用insert命令。

    for(i = 0; i<nums.size();i++){a.insert(map<int,int>::value_type(nums[i], i)); //map<int,int>::value_type类似的是强制类型转化。  转化为pair
    }
    

    方法二:利用数组。

    for(i = 0; i < nums.size(); i++){a[nums[i]] = i;
    }
    
  3. a.count(value值); 类似于find函数。在map中找是否含有value值,有返回1,没有返回0

  4. a.insert( pair格式的 )

  • 核心思想
  1. 第一步:将值存入哈希表map中。
    第二步:利用map的count函数来求解!!!
  2. 注意一个元素不能使用两次,所以a[target-nums[i]] != i !!!
class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {map<int, int> a;vector<int> dp(2, -1);int len = nums.size();for(int i=0; i<len; i++) {a.insert(map<int,int>::value_type(nums[i],i));}for(int i=0; i<len; i++) {if(a.count(target-nums[i])>0 && a[target-nums[i]]!=i) {  //因为一个元素不能使用两次dp[0] = i;dp[1] = a[target-nums[i]];break;  //因为只有一个}}return dp;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/476388.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

汉字转UNICODE?

Function Str_Gb2UniCode(text:String):String; var i,j,len: integer; cur: integer; t: String; ws: widestring; begin Result:; ws:text; len:length(ws); i:1; j:0; while i<len do begin cur:ord(ws[i]); FmtStr(t,%4.4X,[cur]);//BCD转换 Result…

LeetCode 412. Fizz Buzz

1. 题目 写一个程序&#xff0c;输出从 1 到 n 数字的字符串表示。 如果 n 是3的倍数&#xff0c;输出“Fizz” 如果 n 是5的倍数&#xff0c;输出“Buzz” 如果 n 同时是3和5的倍数&#xff0c;输出 “FizzBuzz” 示例&#xff1a; n 15, 返回: ["1","2&…

商务搜索引擎_2019年中国网民搜索引擎使用情况研究报告

中国互联网络信息中心(CNNIC)最新发布《2019年中国网民搜索引擎使用情况研究报告》。报告对中国网民的搜索引擎使用行为&#xff0c;搜索引擎用户属性、满意度和信任度&#xff0c;以及搜索广告接受程度等进行了全面展示&#xff0c;以反映国内搜索引擎业务的发展现状。报告显示…

创建自定义字段类型

演练&#xff1a;创建自定义字段类型 本主题提供了在以下最常见情况下创建自定义字段类型的分步指南&#xff1a;在列表视图和“显示”模式下字段的呈现由字段定义文件中的 RenderPattern 处理&#xff0c;而在“新建”和“编辑”模式下字段的呈现由与 CreateChildControls 方法…

LeetCode之两数相加

1.题目 给出两个 非空 的链表用来表示两个非负的整数。其中&#xff0c;它们各自的位数是按照 逆序 的方式存储的&#xff0c;并且它们的每个节点只能存储一位 数字。 如果&#xff0c;我们将这两个数相加起来&#xff0c;则会返回一个新的链表来表示它们的和。 您可以假设除了…

LeetCode 419. 甲板上的战舰

1. 题目 给定一个二维的甲板&#xff0c; 请计算其中有多少艘战舰。 战舰用 X表示&#xff0c;空位用 .表示。 你需要遵守以下规则&#xff1a; 给你一个有效的甲板&#xff0c;仅由战舰或者空位组成。 战舰只能水平或者垂直放置。 换句话说, 战舰只能由 1xN (1 行, N 列)组…

python展开 c函数中的宏预处理_C 语言常用的预处理-宏函数

#include // 宏函数 三目运算符#define MAX(A, B) A>B?A:B//宏函数 多行 添加\直接回车#define LOOP(FROM, TO, CONTENT)\for(int iFROM;iCONTENT\}//宏函数不需要确定参数类型 普通函数如下int _max(int a, int b) {return a > b ? a : b;}//有相同前缀void cSayHi() …

LeetCode之无重复字符的最长子串

1. 题目 给定一个字符串&#xff0c;请你找出其中不含有重复字符的 最长子串 的长度。示例 1:输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc"&#xff0c;所以其长度为 3。 示例 2:输入: "bbbbb" 输出: 1 解释: 因为无重复…

LeetCode 434. 字符串中的单词数

1. 题目 统计字符串中的单词个数&#xff0c;这里的单词指的是连续的不是空格的字符。 请注意&#xff0c;你可以假定字符串里不包括任何不可打印的字符。 示例: 输入: "Hello, my name is John" 输出: 5 解释: 这里的单词是指连续的不是空格的字符&#xff0c;所…

Symbian中的新手问题整理(二)

最近变得有点懒了&#xff0c;博客也一直没有更新&#xff0c;最近在Symbian的论坛呆的时间比较多&#xff0c;但还是觉得博客园的博客系统最好最稳定。 1、关于Symbian 3rd以后的能力问题 Symbian也是从3rd后才引入签名的机制&#xff0c;这也就涉及到一个签名对应的能力问题。…

PAT乙级1004

题目 读入 n&#xff08;>0&#xff09;名学生的姓名、学号、成绩&#xff0c;分别输出成绩最高和成绩最低学生的姓名和学号。输入格式&#xff1a;每个测试输入包含 1 个测试用例&#xff0c;格式为第 1 行&#xff1a;正整数 n第 2 行&#xff1a;第 1 个学生的姓名 学号…

LeetCode 441. 排列硬币(数学解方程)

1. 题目 你总共有 n 枚硬币&#xff0c;你需要将它们摆成一个阶梯形状&#xff0c;第 k 行就必须正好有 k 枚硬币。 给定一个数字 n&#xff0c;找出可形成完整阶梯行的总行数。 n 是一个非负整数&#xff0c;并且在32位有符号整型的范围内。 示例 1: n 5 硬币可排列成以下…

哭笑不得

1.再逼我,再逼我就装死给你看&#xff01; 2.老子不但有车,还是自行的&#xff01; 3.喜欢的话哥我给你买...(意识到对方的怒意后)啊不,是“哥,我给您买&#xff01;” 4.鄙视我的人那么多,你算老几? 5.打死我也不说,你还没使美人儿计呢&#xff01; 6.我不但手气好,脚气也不错…

python3.6是用来干嘛的_学 Python 都用来干嘛的?

很多人跟你一样&#xff0c;只管闷头学&#xff0c;却不知道为什么去学&#xff0c;往往的理由是&#xff1a;“简单啊”、“收入高啊”、“人生苦短&#xff0c;我用Python”&#xff0c;好吧&#xff0c;那我这里简述下学了Python可以干嘛。当然是为了赚钱啊&#xff0c;哈哈…

PAT真题乙类1006 换个格式输出整数

一、题目 让我们用字母 B 来表示“百”、字母 S 表示“十”&#xff0c;用 12...n 来表示不为零的个位数字 n&#xff08;<10&#xff09;&#xff0c;换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234&#xff0c;因为它有 2 个“百”、3 个“十…

[zz from newsmth] 王大牛的Memory Model reading list

发信人: yifanw (王轶凡), 信区: CPlusPlus 标 题: 内存模型之参考文献 发信站: 水木社区 (Sun Mar 15 22:51:46 2009), 站内 前两篇文章&#xff0c;希望大家多多带着怀疑的态度来读&#xff0c;很有可能有错误。:) 如果想进一步了解&#xff0c;可以看如下文献&#xff1a; …

python简易_Python简易爬虫

Python小爬虫——贴吧图片的爬取在对Python有了一定的基础学习后&#xff0c;进行贴吧图片抓取小程序的编写。目标&#xff1a;首先肯定要实现图片抓取这个基本功能然后实现对用户所给的链接进行抓取最后要有一定的交互&#xff0c;程序不能太傻吧一、页面获取要让python可以进…

PAT乙类1007之素数对猜想

一、题目 让我们定义d​n为&#xff1a;d​npn1−pn&#xff0c;其中p​i是第i个素数。显然有d11&#xff0c;且对于n>1有d​n是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。 现给定任意正整数N(<10​^5)&#xff0c;请计算不超过N的满足猜想的素数对的…

case2

Codeuse dbTempcreate table test(Pid int identity(1,1) not null primary key,Years datetime,IsFirstSixMonths int default(0), --0表示上半年1表示下半年--TotalCome int) insert test select 2007-1-1,0,50union select 2007-3-1,0,60unionselect 2007-12-1,1,80union se…

LeetCode 916. 单词子集(计数)

1. 题目 我们给出两个单词数组 A 和 B。每个单词都是一串小写字母。 现在&#xff0c;如果 b 中的每个字母都出现在 a 中&#xff0c;包括重复出现的字母&#xff0c;那么称单词 b 是单词 a 的子集。 例如&#xff0c;“wrr” 是 “warrior” 的子集&#xff0c;但不是 “wor…