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

wordpress不同分类不同模板 插件wordpress. 外贸seo

wordpress不同分类不同模板 插件,wordpress. 外贸seo,中端网站建设公司,dw网页制作论文文章目录 两数之和判定是否互为字符重排存在重复元素存在重复元素 II字母异位词分组 哈希表:一种存储数据的容器; 可以快速查找某个元素,时间复杂度O(1); 当频繁查找某一个数时,我们可以使用哈希表 创建一个容器&#…

文章目录

  • 两数之和
  • 判定是否互为字符重排
  • 存在重复元素
  • 存在重复元素 II
  • 字母异位词分组

哈希表:一种存储数据的容器;
可以快速查找某个元素,时间复杂度O(1)
频繁查找某一个数时,我们可以使用哈希表

  1. 创建一个容器(unordered_map)
  2. 数组模拟一个简易哈希表

容器

数据结构unordered_mapmapunorded_setset
实现机理hashRBThashRBT
元素格式key+valuekey+valuekeykey
存储规律无序键升序无序键升序
元素重复键不可,值可键不可,值可不可重复不可重复

两数之和

题目:两数之和

在这里插入图片描述
思路

  • 暴力枚举,初始两个指针 i,j,遍历所有二元组,判断nums[i] + nums[j] == target,时间复杂度:O(N^2)
  • 暴力枚举时间复杂度较高的原因是寻找 target - x 的时间复杂度过高,使用哈希表我们可以将查找的时间复杂度降为O(1),对于每一个 x,我们首先查询哈希表中是否存在target - x

我们可以将元素放入到哈希表中的同时,检查表中是否已经存在当前元素所对应的目标元素,这样就可以避免将元素全部放入到哈希表之后再来二次遍历

C++代码

class Solution 
{
public:vector<int> twoSum(vector<int>& numbers, int target) {unordered_map<int, int> hash; // 【数,下标】for(int i = 0; i < numbers.size(); i++){if(hash.find(target - numbers[i]) != hash.end())return {i, hash[target - numbers[i]]};hash[ numbers[i] ] = i;}return {};}
};

判定是否互为字符重排

题目:判定是否互为字符重排

在这里插入图片描述
思路

  • 如果两长度不相等,直接返回fasle
  • 创建一个hash表,对于s1我们添加到hash表中,对于s2中的每个字符如果hash中存在,那么我们删除一个,最后单独遍历一遍hash表,如果其值不等于零也就意味值s1或s2中元素数量不匹配,也就不发重排。

C++代码

class Solution 
{
public:bool CheckPermutation(string s1, string s2) {if(s1.size() != s2.size()) return false;unordered_map<char, int> hash;for(auto ch : s1) hash[ch]++;for(auto ch : s2) hash[ch]--;for(auto x : hash) if(x.second != 0)return false;return true;}};

存在重复元素

题目:存在重复元素

在这里插入图片描述
思路

  • 创建一个hash表,插入元素;
  • 遍历hash表,如果某个元素个数不等于1,返回true;遍历完后如果没有返回,则返回false

C++代码

class Solution 
{
public:bool containsDuplicate(vector<int>& nums) {unordered_map<int, int> hash;for(auto x : nums)hash[x]++;for(auto x : hash)if(x.second != 1) return true;return false;}
};

存在重复元素 II

题目:存在重复元素 II

在这里插入图片描述
思路

  • 和两数之和一样,只需在遇到相同元素时相减判断;

C++代码

class Solution 
{
public:bool containsNearbyDuplicate(vector<int>& nums, int k) {// 【数,下标】unordered_map<int, int> hash;int n = nums.size();for(int i = 0; i < n; i++){// 如果当前元素已经在 hash 中存在if(hash.count(nums[i])){// 判断下标是否满足要求if(i - hash[nums[i]] <= k)return true;}hash[nums[i]] = i;}return false; // 遍历完数组没有发现符合条件的重复元素,返回 false}
};

字母异位词分组

题目: 字母异位词分组

在这里插入图片描述
思路

  • 判断两个字符串是否为字母异位词(排序)
  • unordered_map<string, vector<string>> hash;

C++代码

class Solution 
{
public:vector<vector<string>> groupAnagrams(vector<string>& strs){unordered_map<string, vector<string>> hash;for(auto& s : strs){string tmp = s;sort(tmp.begin(), tmp.end());hash[tmp].push_bacck(s);}vector<vector<string>> ret;for(auto& [k, v] : hash){ret.push_bacck(y);} return ret;}
};
http://www.yayakq.cn/news/441474/

相关文章:

  • 腾讯云提供网站建设吗自己如何做app
  • 制作网站花都种子搜索神器在线引擎
  • 网站模板漏洞wordpress 验证码
  • 国外设计教程网站网页版游戏大全
  • 佛山住房和城乡建设部网站官网淄博网站建设培训
  • 宝塔面板建设二级域名网站访问不了网站后台这么做视频教程
  • 网站推广策划思路是什么建立网站容量
  • 做网站多久学会卖水果网站模板
  • 食品网站开发的背景个人做商城网站大概多少钱
  • 多语言企业网站开发徐汇网站开发培训
  • 手机端做的优秀的网站设计wordpress导入微信
  • 福建省港航建设发展有限公司网站扁平化网站配色
  • 重庆专业网站建设公司排名中国建筑室内设计师网
  • 公司没有备案了网站张家界网站建设多少钱
  • 深圳网站建设公司收费标准建筑工人找活的平台app
  • vancl网站驾校网站建设
  • 做外贸必须建网站吗出词
  • 有人做网赌网站吗环保网站怎么做
  • 做骗子网站织梦cms收费
  • 和京东一样做电子产品的网站企业官网下载
  • 怎么用ps做简单网站首页网站设计广州量计价格
  • 建设工程教育网视频网站自助健站
  • 接网站建设 网站设计广东南方建设工程有限公司网站
  • 天河区pc端网站建设免费网站分析seo报告是坑吗
  • 网站怎么php做微信登录做网站注册的商标类别
  • 学做古装网站苏州专业网站制作方案
  • 备案用网站建设方案wordpress浏览器主题下载
  • 计算机专业论文 网站建设有什么网站开发客户
  • id97网站怎么做的成都创新互联做网站
  • 企业网站开发是什么淘客做网站的话虚拟主机多大