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

网站设计制作从哪crm营销

网站设计制作从哪,crm营销,网站建设策划书ol,龙岗新闻最新消息今天【java数据结构】HashMapOJ练习题 一、只出现一次的数字二 、随机链表的复制三 、宝石与石头四、坏键盘打字五、前K个高频单词 博客最后附有整篇博客的全部代码!!! 一、只出现一次的数字 只出现一次的数字 思路: 先遍历一遍数组…

【java数据结构】HashMapOJ练习题

  • 一、只出现一次的数字
  • 二 、随机链表的复制
  • 三 、宝石与石头
  • 四、坏键盘打字
  • 五、前K个高频单词

博客最后附有整篇博客的全部代码!!!

一、只出现一次的数字

只出现一次的数字
思路:

  1. 先遍历一遍数组,将所有元素全部存到HashMap集合中
  2. 再遍历一遍数组,获取每个值对应的values值,判断是否等于1

代码:

 public int singleNumber(int[] nums) {HashMap<Integer,Integer> hashMap=new HashMap<>();for(int i=0;i<nums.length;i++){if(hashMap.containsKey(nums[i])){hashMap.put(nums[i],hashMap.get(nums[i])+1);}else{hashMap.put(nums[i],1);}}for(int i=0;i<nums.length;i++){if(hashMap.containsKey(nums[i])){if(hashMap.get(nums[i])==1){return nums[i];}}}return -1;}

二 、随机链表的复制

随机链表的复制
思路:

  1. 定义HashMap来存储新老节点的映射关系
  2. 再遍历一遍,然后通过老节点的map.get().next和map.get().random获得新节点的next和random,最后再通过老节点的map.get(cur.next)和map.get(cur.random)映射出应赋值给新节点的next和random的值

map.get(cur).next = map.get(cur.next);
map.get(cur).random =map.get(cur.random);

代码:

        public Node copyRandomList(Node head) {Node cur = head;HashMap<Node, Node> map = new HashMap<>();while (cur != null) {Node newNode = new Node(cur.val);map.put(cur,newNode);cur = cur.next;}cur=head;while (cur != null) {map.get(cur).next = map.get(cur.next);map.get(cur).random = map.get(cur.random);cur=cur.next;}return map.get(head);}

三 、宝石与石头

宝石与石头
思路:

  1. 现将字符串转化为字符数组
  2. 将石头的每个字符存储进HashMap中,然后遍历宝石,如果HashMap中存在宝石,通过map.get()获取values值,进行count++;最后返回count。

代码:

    public int numJewelsInStones(String jewels, String stones) {char[] jewelChars = jewels.toCharArray();//宝石char[] stonesChars = stones.toCharArray();//石头int count = 0;HashMap<Character,Integer> map=new HashMap<>();for(int i = 0; i < stonesChars.length; i++){if(map.containsKey(stonesChars[i])){map.put(stonesChars[i],map.get(stonesChars[i])+1);}else{map.put(stonesChars[i],1);}}for(int i = 0; i<jewelChars.length; i++){if(map.containsKey(jewelChars[i])){count+=map.get(jewelChars[i]);}}return count;}

四、坏键盘打字

坏键盘打字
思路:

  1. 将所有的字符串全部进行大写转化
  2. 将输出的字存储进HashMap的map1集合中
  3. 遍历打印的字,并且只要求输出一遍我们将出现过的字符可以重新放到一个HashMap的map2集合中,判断map1和map2两个如果都不包含则进行打印。

代码:

    public static void main(String[] args) {Scanner sc = new Scanner(System.in);String str1= sc.nextLine();String str2=sc.nextLine();faultyKeyboard(str1,str2);}public static void faultyKeyboard(String str1,String str2){String str3=str1.toUpperCase();String str4=str2.toUpperCase();char[] str5=str3.toCharArray();char[] str6=str4.toCharArray();HashMap<Character,Integer> map1=new HashMap<>();HashMap<Character,Integer> map2=new HashMap<>();for (int i = 0; i < str6.length; i++) {if(map1.containsKey(str6[i])){map1.put(str6[i],map1.get(str6[i])+1);}else{map1.put(str6[i],1);}}for(int i=0;i<str5.length;i++){if(!map1.containsKey(str5[i])&&!map2.containsKey(str5[i])){map2.put(str5[i],1);System.out.print(str5[i]);}}}

五、前K个高频单词

前K个高频单词
思路:

  1. 将每个单词存储进HashMap的map集合
  2. 建立小根堆(在未建立好K大小的小根堆的时候,这个时候如果遇到频率相同的单词,需要j建立成大根堆)
  3. 遍历map,先建立好k个大小的小跟堆,堆顶元素小于入堆元素,则插入入堆元素;堆顶元素等于入堆元素,则判断单词大小,小的入堆

代码:

    public List<String> topKFrequent(String[] words, int k) {HashMap<String, Integer> map = new HashMap<>();for (String word : words) {map.put(word, map.getOrDefault(word, 0) + 1);}//2. 建立小根堆PriorityQueue<Map.Entry<String,Integer>> minHeap = new PriorityQueue<>(new Comparator<Map.Entry<String, Integer>>() {@Overridepublic int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {if(o1.getValue().compareTo(o2.getValue()) == 0) {return o2.getKey().compareTo(o1.getKey());}return o1.getValue().compareTo(o2.getValue());}});//3.遍历mapfor(Map.Entry<String,Integer> entry : map.entrySet()) {if(minHeap.size() < k) {minHeap.offer(entry);}else {Map.Entry<String,Integer> top = minHeap.peek();if(top.getValue().compareTo(entry.getValue()) < 0) {minHeap.poll();minHeap.offer(entry);}else if(top.getValue().compareTo(entry.getValue()) == 0) {if(top.getKey().compareTo(entry.getKey()) > 0) {minHeap.poll();minHeap.offer(entry);}}}}ArrayList<String> list = new ArrayList<>();for (int i = 0; i < k; i++) {Map.Entry<String,Integer> tmp = minHeap.poll();list.add(tmp.getKey());}Collections.reverse(list);return list;}

此篇博客的全部代码!!!

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

相关文章:

  • 浙江网站建设优化网站编排页面
  • 做seo推广网站潍坊网站定制公司
  • 双语企业网站wordpress 自定义rss
  • 网站作品集韩国漫画漫免费观看免费
  • 合肥网站网站建设北京正规网站建设有几种
  • 建设无障碍网站背景全屏网站
  • vi设计品牌图片企业网站优化与推广
  • 网站建设丂金手指科杰全免费云游戏网页在线玩
  • 网站 永久关停 请示安卓门户网站开发
  • 南宁市住房和城乡建设局网站html5门户网站模板
  • steam官方网站下载抖音代运营合同模板免费
  • 网站开发 职位描述网站建设和维护实训
  • 外贸网站优化谷歌关键词排名php网站如何导入数据库
  • 建设报考网站查询成绩可以设计房子布局的软件
  • 在线做托福的网站东莞网站建设周期
  • 易语言用电脑做网站服务器海南新闻在线新闻中心
  • 建设网站不要服务器可以吗上海4a广告公司排名
  • 深圳商业网站建设怎么样嘉兴建企业网站
  • 网站推广效果软件之家
  • 江苏省华建建设股份有限网站网站概述怎么写
  • 网络推广网站培训团购网站怎么做
  • 罗定网站建设顺德公益网站制作
  • 网站制作用什么编程行业网站推广外包
  • 网站默认地区数据修改网站建设合作协议文本
  • ppt 做的最好的网站推广平台
  • 网页设计与网站建设课程总结个人手机网站大全
  • 网站建设属于哪个税目nike网站建设方案
  • 中国建设工程质量安全管理协会网站阿里巴巴上面可以做网站
  • 手机上的网站和pc机上的网站的区别怎么做质量高的网站
  • 无锡电子商务网站建设公司asp.net 网站开发 pdf