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

国内最有趣的网站重庆网站建设费用

国内最有趣的网站,重庆网站建设费用,seo营销是指,优化营商环境建议DAY5休息一天,今天重启~ 哈希表理论基础:代码随想录 Java hash实现 :java 哈希表-CSDN博客 一、LeetCode 242 有效的字母异位词 题目链接:242.有效的字母异位词 思路:设置字典 class Solution {public boolean isAnag…

DAY5休息一天,今天重启~

哈希表理论基础:代码随想录

Java hash实现 :java 哈希表-CSDN博客

一、LeetCode 242 有效的字母异位词

题目链接:242.有效的字母异位词

思路:设置字典

class Solution {public boolean isAnagram(String s, String t) {int slen = s.length(), tlen = t.length();if(slen != tlen){return false;}int[] alp = new int[26];            //设置字典存储字母信息for(int i = 0; i < slen; i++){alp[s.charAt(i) - 'a']++;alp[t.charAt(i) - 'a']--;}for(int i = 0; i < 26; i++){if(alp[i] != 0){return false;}}return true;}
}

 二、LeetCode 349 两个数组的交集

思路:利用哈希表的无序性、唯一性求交集。

class Solution {public int[] intersection(int[] nums1, int[] nums2) {//哈希set无序唯一Set<Integer> set1 = new HashSet<>();Set<Integer> set2 = new HashSet<>();for(int a:nums1){set1.add(a);}for(int a:nums2){if(set1.contains(a)){set2.add(a);}}int n =  set2.size();int[] ans = new int[n];int index = 0;//加强循环遍历for(int num : set2){ans[index++] = num;}return ans;}
}

补充:HashSet遍历的三种方式

        ①迭代器遍历

        ②转换为List遍历

        ③增强for循环遍历

//迭代器遍历
Iterator iterator = set.iterator();
while (iterator.hasNext()) {System.out.println(iterator.next());			
}
//转换为List遍历
List<Integer> list = new ArrayList<>(set);
for(int i : list){System.out.println(i);
}
//增强for循环遍历
for(int i : set){System.out.println(i);
}

三、LeetCode 202 快乐数

题目链接:202.快乐数icon-default.png?t=N7T8https://leetcode.cn/problems/happy-number/submissions/499209933/

思路:设置哈希表记录出现过的数,出现循环即终止。

class Solution {public boolean isHappy(int n) {Set<Integer> set = new HashSet<>();while(n != 1){int sum = 0, temp = n;while(temp != 0){int x = temp%10;temp /= 10;sum += x*x;}if(set.contains(sum)){return false;}set.add(sum);n = sum;}return true;}
}

四、LeetCode 1 两数之和

题目链接:1.两数之和icon-default.png?t=N7T8https://leetcode.cn/problems/two-sum/description/

思路:以数值为Key、下标为Value,建立映射关系并使用HashMap存储;使用HashMap的containsKey()方法和get()方法获取符合条件的数值下标。

class Solution {public int[] twoSum(int[] nums, int target) {Map<Integer,Integer> map = new HashMap<>();    //数值为Key、下标为Valueint[] ans = new int[2];for(int i = 0; i < nums.length; i++){if(map.containsKey(target - nums[i])){ans[0] = map.get(target - nums[i]);ans[1] = i;return ans;}map.put(nums[i],i);}return ans;}
}

 补充:HashMap常用方法

//添加键值对
put(Object key, Object value) //添加指定的映射关系到目标映射关系
putAll(Collection c)//根据键来获取对应的值
get(Object key) //map中存在key则使用对应的value,否则使用defaultValue
getOrDefault(Object key, V defaultValue)//是否有指定key的映射 
containsKey(Object key)//是否有指定value的映射
containsValue(Object value)//删除该键值对
remove(Object key) //返回所有值,返回形式为Collection
values() //测试映射是否为空
isEmpty()//返回大小
size()

五、今日小结

        回顾了哈希表的原理和Java哈希表底层逻辑实现,重温了HashSet、HashMap的用法,题目难度不大,是摸鱼的一天OVO!明天也要加油~

http://www.yayakq.cn/news/668045/

相关文章:

  • 金融网站源码 asp网站建设东北
  • 商城微网站开发微网站网站系统开发
  • 做网站要先买域名吗wordpress修改后台登录地址
  • 网页设计的网站配色方案上海网站 备案查询
  • 沧州模板建站平台网络规划设计师和系统架构师哪个好考
  • 织梦模板 行业网站网站注册怎么做屏蔽过滤
  • 定制网站建设官网磁贴式网站模板
  • 做网站在自己电脑建立虚拟机门户网站如何建设方案
  • 湖南营销网站建设棋牌软件开发多少钱
  • 制作网站的钱哪里做公司网站比较好
  • 建设环保网站的目的与功能分析h5微场景制作软件
  • 网站建设工作总结做外贸的社交网站有哪些
  • 广州十度网络网站开发最好设计师 网站
  • 有什么正规的网站做代加工济南注册公司怎么注册
  • 建设实木餐桌椅移动网站如何做彩票网站推广图
  • 网站打开速度慢是否需要升级带宽手机版网站制作
  • 建站工具word稻壳企业网站模板
  • 网站建设与维护的实训总结网站开发商城1688
  • 广州自助网站设计平台网络营销的三种方式
  • 找论文的免费网站净水设备 技术支持 东莞网站建设
  • 做设计有必要买素材网站会员吗网站建设费用计入什么科目
  • 小鱼儿外贸网站公众号开发者密码怎么启用
  • 西宁做网站最好的公司哪家好海城网站制作
  • 新网站怎样做好外链自做淘宝客网站
  • 博物馆网站页面设计说明影视投资销售怎么找客户
  • 大学生帮别人做网站专业网站推广服务咨询
  • 做网站需要看的书男人直接做的视频网站
  • 网站建设的主要工作消除wordpress
  • 文书写作网站汽车营销活动策划方案
  • 青岛网站开发学校唐山哪里建设网站好