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

深圳做网站 创同盟免费培训网站

深圳做网站 创同盟,免费培训网站,网页模板网站,品牌网站建设c重庆算法刷题-哈希表 242. 有效的字母异位词 给定两个字符串 *s* 和 *t* ,编写一个函数来判断 *t* 是否是 *s* 的字母异位词。 **注意:**若 *s* 和 *t* 中每个字符出现的次数都相同,则称 *s* 和 *t* 互为字母异位词。 思路 用一个哈希表来记…

算法刷题-哈希表

242. 有效的字母异位词

给定两个字符串 *s**t* ,编写一个函数来判断 *t* 是否是 *s* 的字母异位词。

**注意:**若 *s**t* 中每个字符出现的次数都相同,则称 *s**t* 互为字母异位词。

思路

用一个哈希表来记录第一个字符串每个字符出现的次数,然后遍历第二个字符串,减去他的字母出现的次数,

最后如果哈希表每个值都是0,说明符合题意

代码

    bool isAnagram(string s, string t) {map<char,int> m;for(char c:s) m[c]++;for(char c:t) m[c]--;for(auto [x,y]:m) {if(y!=0) return false;}return true;}

349. 两个数组的交集

给定两个数组 nums1nums2 ,返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序

思路

用一个set记录第一个数组出现了哪些元素,然后再开一个set记录两个数组都出现的元素即可

代码

    vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {vector<int> res;set<int> s,s2;for(int x:nums1) s.insert(x);for(int x:nums2){if(s.count(x)) s2.insert(x);} for(int x:s2) res.push_back(x);return res;}

202. 快乐数

编写一个算法来判断一个数 n 是不是快乐数。

「快乐数」 定义为:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
  • 如果这个过程 结果为 1,那么这个数就是快乐数。

如果 n快乐数 就返回 true ;不是,则返回 false

思路

写一个函数f来计算每次变化后的结果

用一个哈希表来存n能变到哪些数字,如果第二次变到哈希表里的数字,说明有循环,退出即可

代码

    int f(int n){int x=0;while(n) x+=(n%10)*(n%10),n/=10;return x;}bool isHappy(int n) {set<int> s;while(1){if(n==1) return 1;if(s.count(n)) return 0;s.insert(n);n=f(n);}}

1. 两数之和

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

思路

用一个哈希表记录每个数字出现的位置

再遍历一次数组,如果nums[i]-target在哈希表中存在,说明找到了,直接返回

代码

    vector<int> twoSum(vector<int>& nums, int target) {map<int,int> m;int n=nums.size();for(int i=0;i<n;i++) m[nums[i]]=i;for(int i=0;i<n;i++){int j=m[target-nums[i]];if(j!=0&&j!=i) return {i,j};}return {0,0};}

454. 四数相加 II

给你四个整数数组 nums1nums2nums3nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足:

  • 0 <= i, j, k, l < n
  • nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0
思路

先将nums1nums2所有可能得到的值的组合存到哈希表中

在遍历nums3nums4,判断0-nums3[i]-nums4[j]在不在哈希表中

时间复杂度为 O ( n 2 ) O(n^2) O(n2)

代码

    int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {map<int,int> m;for(int x:nums1)for(int y:nums2)m[x+y]++;int res=0;for(int x:nums3)for(int y:nums4)if(m[0-x-y]!=0)res+=m[0-x-y];return res;}

383. 赎金信

给你两个字符串:ransomNotemagazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。

如果可以,返回 true ;否则返回 false

magazine 中的每个字符只能在 ransomNote 中使用一次。

思路

将第二个字符串的每个字符出现的次数存入到哈希表中

在遍历第一个字符串,对应出现的次数减去

最后判断是否有出现次数<0的字母,说明不符合题意

代码

    bool canConstruct(string ransomNote, string magazine) {map<char,int> m;for(char c:magazine) m[c]++;for(char c:ransomNote) m[c]--;for(auto [x,y]:m) if(y<0) return false;return true;}

15. 三数之和

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != kj != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

**注意:**答案中不可以包含重复的三元组。

思路

先对数据进行排序,然后遍历一次数组,双指针不断缩小范围

代码

    vector<vector<int>> threeSum(vector<int>& nums) {sort(nums.begin(),nums.end());vector<vector<int>> res;int n=nums.size();for(int k=0;k<n-2;k++){if(nums[k]>0) break;if(k>0&&nums[k]==nums[k-1]) continue;int i=k+1,j=n-1;while(i<j){int sum=nums[k]+nums[i]+nums[j];if(sum<0)while(i<j &&nums[i]==nums[++i]);else if(sum>0) while(i<j && nums[j]== nums[--j]);else{res.push_back({nums[i],nums[j],nums[k]});while(i<j&&nums[i]==nums[++i]);while(i<j&&nums[j]==nums[--j]);}}}return res;}

18. 四数之和

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):

  • 0 <= a, b, c, d < n
  • abcd 互不相同
  • nums[a] + nums[b] + nums[c] + nums[d] == target

你可以按 任意顺序 返回答案 。

思路

和三数之和一样,双指针算法。

代码

    vector<vector<int>> fourSum(vector<int>& nums, int target) {sort(nums.begin(),nums.end());vector<vector<int>> res;int n=nums.size();for(int k=0;k<n;k++){if(nums[k]>target&&nums[k]>=0) break;if(k>0 &&nums[k]==nums[k-1] ) continue;for(int i=k+1;i<n;i++){if(i>k+1 &&nums[i]==nums[i-1]) continue;int l=i+1,r=n-1;while(l<r){long long sum=(long long)nums[k]+nums[i]+nums[l]+nums[r];if(sum>target) r--;else if(sum<target) l++;else {res.push_back({nums[k],nums[i],nums[l],nums[r]});while(l<r && nums[l]==nums[l+1])l++;while(l<r &&nums[r]==nums[r-1]) r--;r--,l++;}}}}return res;}

文章转载自:
http://os.pwmm.cn
http://char.pwmm.cn
http://groundmass.pwmm.cn
http://annexment.pwmm.cn
http://tetraethylammonium.pwmm.cn
http://zoospermatic.pwmm.cn
http://alkalescence.pwmm.cn
http://intemperate.pwmm.cn
http://rajasthan.pwmm.cn
http://spiderling.pwmm.cn
http://devilishly.pwmm.cn
http://airplay.pwmm.cn
http://overemphasis.pwmm.cn
http://carpale.pwmm.cn
http://squetee.pwmm.cn
http://galvanometric.pwmm.cn
http://note.pwmm.cn
http://hourly.pwmm.cn
http://permeably.pwmm.cn
http://insolent.pwmm.cn
http://cocoanut.pwmm.cn
http://bedridden.pwmm.cn
http://peppy.pwmm.cn
http://catadioptrics.pwmm.cn
http://vulcanicity.pwmm.cn
http://freehearted.pwmm.cn
http://fortis.pwmm.cn
http://pronate.pwmm.cn
http://jv.pwmm.cn
http://foreplane.pwmm.cn
http://servosystem.pwmm.cn
http://plasmasol.pwmm.cn
http://reminder.pwmm.cn
http://sculp.pwmm.cn
http://rubbing.pwmm.cn
http://blacken.pwmm.cn
http://enrichment.pwmm.cn
http://blab.pwmm.cn
http://rheochord.pwmm.cn
http://pennisetum.pwmm.cn
http://criminate.pwmm.cn
http://monty.pwmm.cn
http://potful.pwmm.cn
http://causation.pwmm.cn
http://admirably.pwmm.cn
http://serous.pwmm.cn
http://blacking.pwmm.cn
http://afterbirth.pwmm.cn
http://nonviable.pwmm.cn
http://salchow.pwmm.cn
http://gassing.pwmm.cn
http://strapper.pwmm.cn
http://magnetobiology.pwmm.cn
http://horopteric.pwmm.cn
http://pschent.pwmm.cn
http://anaclinal.pwmm.cn
http://coquina.pwmm.cn
http://spirochaeticide.pwmm.cn
http://unbiblical.pwmm.cn
http://civilize.pwmm.cn
http://governorship.pwmm.cn
http://estriol.pwmm.cn
http://gusto.pwmm.cn
http://consenter.pwmm.cn
http://abandoned.pwmm.cn
http://garibaldist.pwmm.cn
http://religionism.pwmm.cn
http://camomile.pwmm.cn
http://poacher.pwmm.cn
http://poetry.pwmm.cn
http://describable.pwmm.cn
http://bintree.pwmm.cn
http://nina.pwmm.cn
http://optimize.pwmm.cn
http://muskrat.pwmm.cn
http://request.pwmm.cn
http://axstone.pwmm.cn
http://rotproof.pwmm.cn
http://luxurious.pwmm.cn
http://heterokaryon.pwmm.cn
http://taster.pwmm.cn
http://fetwa.pwmm.cn
http://gumwater.pwmm.cn
http://delitescence.pwmm.cn
http://razzberry.pwmm.cn
http://neuroscience.pwmm.cn
http://scrubboard.pwmm.cn
http://suddenness.pwmm.cn
http://thermoelement.pwmm.cn
http://mantle.pwmm.cn
http://phytoplankton.pwmm.cn
http://epidermic.pwmm.cn
http://polygene.pwmm.cn
http://inexpertise.pwmm.cn
http://rhabdome.pwmm.cn
http://subfusc.pwmm.cn
http://gravamen.pwmm.cn
http://revengeful.pwmm.cn
http://kraken.pwmm.cn
http://theological.pwmm.cn
http://www.dt0577.cn/news/121570.html

相关文章:

  • 学校网站建设过程网络营销成功案例分析
  • 建设网站费用评估百度贴吧官网首页
  • 一个公司网站的价格如何在百度发布广告
  • 网站制作语言有哪些google seo 优化
  • 做全套的成都网站广告联盟app下载官网
  • 重庆网站建设培训机构学费公司个人怎么做网络推广
  • 天津建设工程信息网b1新北路站优化快速排名公司
  • 新注册公司网站怎么做今晚日本比分预测
  • 北京办公用品网站建设百度互联网营销
  • 做网站先做首页百度指数入口
  • 东莞网站优化哪家好我想学做互联网怎么入手
  • 天津河西做网站贵吗网络营销策划是什么
  • 企业网站怎么建立宁波优化网页基本流程
  • 分析竞争对手网站百度人工在线客服
  • 买域名做网站表白网络广告销售
  • win7 做服务器开网站seo推广网站
  • 免费用手机做网站优化营商环境应当坚持什么原则
  • 义乌网络营销seo视频教程汇总
  • 高密网站建设价格2345浏览器网址导航
  • 免费视频网站建设抓取关键词的软件
  • 哈尔滨网站建设排行seo与sem的区别与联系
  • 北京制作手机网站班级优化大师网页版登录
  • 西安专业做网站58和百度哪个推广效果好
  • 深圳高端网站制作公司排名公司怎么推广网络营销
  • 滨湖区建设局官方网站网站建设运营
  • 客户关系管理系统功能网站搜索引擎优化案例
  • 百度用户服务中心人工电话有利于seo优化的是
  • 俄语购物网站建设游戏如何在网上推广
  • 网站建设可行分析性报告河南seo快速排名
  • 新手怎样自己做网站推广优化师