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

湖南省网站建设项目网站关键词推广企业

湖南省网站建设项目,网站关键词推广企业,湛江做网站需要什么,wordpress文章大纲插件先验知识记录: 遇到哈希问题,想到三种数据结构: ①数组:适用于哈希值比较小,范围较小, ②set:适用于哈希值较大。 ③map:如果需要用到键值对,则用之。 242.有效的字母…

先验知识记录:

遇到哈希问题,想到三种数据结构:

①数组:适用于哈希值比较小,范围较小,

②set:适用于哈希值较大。

③map:如果需要用到键值对,则用之。


242.有效的字母异位符。

代码随想录链接

力扣链接

问题描述:

就是看两个字符串里面的字符是不是一样的,它们包含的字母以及个数是否是一致的。

思路:

因为单个字母总共有26个,所以建立数组形式的hash表。初始的hash表各个元素为0。经过字符串1的遍历后,hash表此时对应位置的字母数为字符串1的字母数。

再去遍历字符串2,如果遍历后的hash字母表存在字母对应的值不为0,则说明两个字符串包含的字母及字母数不同。如果每个hash表中每个位置的字母都为0,那么说明两个字符串中是异位关系。

注意,此时hash表中的字母位置,使用hash[string1[i]-'a']表示,这个很妙,因为这就相当于取出字符串每个字符对应到hash数组中且一一对应。

伪代码:

新建数组hash字母表
遍历字符串1对对应位置的hash字母表数值+1,表示字符串1中的hash字母表中字母个数
遍历字符串2对对应位置的hash字母表数值-1,表示字符串2中的hash字母表字母个数-字符串1中对应位置的字母个数
遍历hash字母表如果某个位置不为0说明两个字符串不是异味关系,返回false
遍历完成后,返回true

代码:

bool isAnagram(string s, string t) {int hash[26]={0};for(int i  =0 ; i<s.size();i++){//遍历字符串s,使得s对应的字母表每个都有其对应次数。//s[i]就是s的每个字符,s[i]-‘a’代表了其对应哈希表的索引从0-25。字符串t同理。hash[s[i]-'a']++;}for(int i = 0 ; i< t.size() ; i++){hash[t[i]-'a']--;}for(int i = 0 ; i < 26; i++){if (hash[i]!=0){return false;}}return true;
}

349.两个数组的交集。

代码随想录链接

力扣链接

问题描述

两个数组,取交集,最后的结果要不重复。

思路:

有两种思路解决:

①set,将数组1的元素存入set去重。遍历数组2,如果元素在set中,则放入另个集合中,作为返回值返回。

遍历数组1,将数组中每个元素去重后放入number_set中
遍历数组2如果数组2中有元素在number_set中则放入result_set中
将result_set转为vector,作为返回值返回

②数组,力扣上有数组中单个元素大小限制,故将hash表数组设置为1000出头的大小。

新建hash表,大小为1000出头
遍历数组1对数组1的每个元素放到hash数组中,为1.
遍历数组2如果数组中有数字对应hash值为1将元素放入result_set中
将result_set转为vector,作为返回值返回

解法①代码:

vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {set<int> result_set;//方法1set<int> number_set ;for(int i = 0 ; i < nums1.size() ; i++){number_set.insert(nums1[i]);}for(int i = 0 ; i< nums2.size();i++){if (number_set.find(nums2[i])!= number_set.end()){result_set.insert(nums2[i]);}}vector <int> vt;vt.assign(result_set.begin(),result_set.end());return vt;
}

解法②代码:

vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {set<int> result_set;//方法2int hash[1001]={0};//遍历nums1,若有数字,则为1for(int i = 0 ; i < nums1.size() ; i++){hash[nums1[i]]=1;}for(int i = 0 ; i < nums2.size();i++){if (hash[nums2[i]]){result_set.insert(nums2[i]);}}vector <int> vt;vt.assign(result_set.begin(),result_set.end());return vt;
}
http://www.yayakq.cn/news/139500/

相关文章:

  • 京伦网站建设wordpress恶意代码在线检测
  • 个人网站百度推广收费网站制作哪家专业
  • 怎样才能制作网站国家信用信息系统
  • 乐山高端网站建设wordpress新增数据字段及展示
  • 深圳企业网站建设服务中心百度贴吧官网网页
  • wordpress 替代品seo的描述正确
  • 模板网站外贸建站今天福州发生的重大新闻
  • 网站设计论文参考文献做百度竞价用什么网站
  • 东莞大朗网站建设哪家口碑好上海专业高端网站建设服
  • iis7.5 部署网站重庆建设工程招标信息网
  • 网站建设对工厂意义dede网站wap
  • 视频网站中滑动列表怎么做南漳网站开发
  • php网站源代码铜陵市企业网站建设
  • 网站公司做的网站有最字佛山 网站建设培训班
  • 网站设计开发项目书重庆品牌型网站建设
  • 有哪些网站可以兼职做笔译邢台企业做网站费用
  • 做生意网站庆阳手机网站设计
  • 重庆做网站建设的公司哪家好统计二级域名的网站流量有什么用
  • 驾校网上约车网站开发wordpress文章标题总有网站名
  • 局域网站点建设方案中国男女直接做的视频网站
  • 深圳手机机械网站建设wordpress 启动
  • show t团队网站艰涩网站原型设计流程
  • 公司简介网站怎么做wordpress app中文版下载
  • 站长统计 网站统计注册域名平台
  • 威海北京网站建设网站永久空间
  • seo网站架构设计宁波公司注册流程
  • 苏州制作企业网站公司wordpress编辑网站
  • 中建豪城建设有限公司网站公司牌子设计图
  • 做建站较好的网站珠海 网站建设
  • 营销型网站 案例成都商城类网站设计