数据结构——用链表实现Map

目录

一、映射(Map)

二、代码实现

1.建立接口

2.方法实现

(1)映射的建立

键(key)和值(val)的建立

重写toString方法

(2)构造方法

(3)判断是否为空

(4)添加元素

(5)修改元素

(6)打印映射

(7)判断元素是否存在

(8)获取元素个数

(9)获取元素

(10)删除元素

3.方法调用

 三、对应题目


一、映射(Map)

映射(Maps)用于存储键值对,常见的实现有 HashMap 和 TreeMap。

在Java方法中可以直接调用

Map<String, Integer> hashMap = new HashMap<>();
Map<String, Integer> treeMap = new TreeMap<>();

HashMap:

  • 特点: 基于哈希表实现的键值对存储结构。
  • 优点: 高效的查找、插入和删除操作。
  • 缺点: 无序,不保证顺序。

TreeMap:

  • 特点: 基于红黑树实现的有序键值对存储结构。
  • 优点: 有序,支持按照键的顺序遍历。
  • 缺点: 插入和删除相对较慢。

映射是存储数据对(key,value)的数据结构

根据键(key),寻找值(value)

二、代码实现

1.建立接口

package com.algo.lesson.lesson05.map;public interface SelfMap<K,V> {//判断集合是否为空boolean isEmpty();//获取集合中元素的个数int getSize();//判断key是否存在boolean containsKey(K key);//根据key获取值V fetValueByKey(K key);//向集合中添加元素void put(K key,V val);//删除集合中的元素(根据key删除)boolean removeByKey(K key);//修改key修改值void set(K key ,V val);//打印map集合中的所有元素【key:val】void show();
}

2.方法实现

(1)映射的建立

键(key)和值(val)的建立
K key;V val;Node next;public Node(K key, V val) {this.key = key;this.val = val;this.next = null;}public Node(K key, V val, Node next) {this(key, val);this.next = next;}private Node<K, V> head;private int size;
重写toString方法

打印的时候,为了能方便我们观察,我们可以重写toString方法,按照我们希望的格式去输出

@Overridepublic String toString() {return "[" + this.key + ":" + this.val + "]";}}

(2)构造方法

public LinkedData() {Node<K, V> dummyHead = new Node(null, null);this.head = dummyHead;this.size = 0;}

(3)判断是否为空

public boolean isEmpty() {return this.size == 0;}

(4)添加元素

头部添加

public void addHead(K key, V val) {add(0, key, val);}public void add(int index, K key, V val) {if (index < 0 || index > this.size) {throw new IllegalArgumentException("index is invalid.");}Node<K, V> node = new Node(key, val);Node<K, V> pre = this.head;for (int i = 1; i <= index; i++) {pre = pre.next;}node.next = pre.next;pre.next = node;this.size++;}

(5)修改元素

传入键和值,返回boolean类型判断是否修改成功

public boolean set(K key,V val){Node<K, V> curNode = this.head.next;while (curNode != null) {if (curNode.key.equals(key)) {curNode.val=val;return true;}curNode = curNode.next;}return false;}

(6)打印映射

@Overridepublic String toString() {Node<K, V> curNode = this.head.next;StringBuilder sb = new StringBuilder();while (curNode != null) {sb.append(curNode + "-->");curNode = curNode.next;}sb.append("null");return sb.toString();}

(7)判断元素是否存在

 public boolean contain(K key) {Node<K, V> curNode = this.head.next;while (curNode != null) {if (curNode.key.equals(key)) {return true;}curNode = curNode.next;}return false;}

(8)获取元素个数

public int getSize() {return this.size;}

(9)获取元素

根据键(key)获取值(val)

 public V get(K key) {Node<K, V> curNode = this.head.next;while (curNode != null) {if (curNode.key.equals(key)) {return curNode.val;}curNode = curNode.next;}return null;}

(10)删除元素

返回boolean值,判断是否删除成功

public boolean remove(K key) {Node<K, V> pre = this.head;while (pre.next != null) {Node<K, V> delNode = pre.next;if (delNode.key.equals(key)) {pre.next = pre.next.next;delNode.next = null;this.size--;return true;}pre = pre.next;}return false;}

3.方法调用

        继承SelfMap的接口,将其中的方法全部重写,然后进行调用,调取自己已经写好的代码,以此来实现Map

package com.algo.lesson.lesson05.map;public class LinkedMap<K, V> implements SelfMap<K, V> {private LinkedData<K, V> data;public LinkedMap(){this.data=new LinkedData<>();}@Overridepublic boolean isEmpty() {return this.data.isEmpty();}@Overridepublic int getSize() {return this.data.getSize();}@Overridepublic boolean containsKey(K key) {return this.data.contain(key);}@Overridepublic V fetValueByKey(K key) {return this.data.get(key);}@Overridepublic void put(K key, V val) {this.data.addHead(key,val);}@Overridepublic boolean removeByKey(K key) {return this.data.remove(key);}@Overridepublic void set(K key, V val) {boolean ret= this.data.set(key,val);System.out.println(ret?"successful":"failed");}@Overridepublic void show() {System.out.println(this.data);}
}

 三、对应题目

350. 两个数组的交集 II力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目利用映射(哈希表)来解决,感兴趣可以去LeetCode上尝试一下

class Solution {public int[] intersect(int[] nums1, int[] nums2) {if(nums1.length>nums2.length){return intersect(nums2,nums1);}Map<Integer,Integer>map=new HashMap<Integer,Integer>();for(int num:nums1){int count=map.getOrDefault(num,0)+1;map.put(num,count);}int[]intersection=new int[nums1.length];int index=0;for(int num:nums2){int count=map.getOrDefault(num,0);if(count>0){intersection[index++]=num;count--;if(count>0){map.put(num,count);}else{map.remove(num);}}}return Arrays.copyOfRange(intersection,0,index);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/650417.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

102.乐理基础-五线谱-高音谱号

内容参考于&#xff1a;三分钟音乐社 上一个内容&#xff1a;五线谱的构造、谱号是什么-CSDN博客 谱号一共需要学习和了解四种&#xff0c;如下图&#xff1a;要牢牢掌握的是高音谱号和低音谱号这两种&#xff0c;如图1所示 首先高音谱号&#xff1a; 它大致范围&#xff0c;…

yield关键字

如果是第一次遇到这个关键字&#xff0c;可以直接使用下文中小标题为Next的代码设置断点看一下效果 带yield的函数是一个生成器&#xff0c;而不再是一般意义上的一个函数。yield在函数中的功能类似于return&#xff0c;不同的是yield每次返回结果之后函数并没有退出&#xff…

clang--cpplint--gitlint

clang_format clang_format是什么 代码格式化工具 官网和教程 下载 sudo apt install clang sudo apt install clang-format#查看下载是否成功 clang --version 代码的构建到提交的过程&#xff1a; cmake .. make make test make clang_format_check cpplint cpplin…

Vue3中的ref和shallowRef、reactive和shallowReactive

一&#xff1a;ref、reactive简介 ref和reactive是Vue3中定义响应式数据的一种方式。ref通常用来定义基础类型数据。reactive通常用来定义复杂类型数据。 二、shallowRef、shallowReactive简介 shallowRef和shallowReactive是Vue3中定义浅层次响应式数据的方式 三、Api使用对比…

Mac中java jdk、android sdk、flutter sdk目录

1、Java JDK 目录 &#xff08;1&#xff09;官网下载的 Java JDK Java JDK下载官网 /Library/Java/JavaVirtualMachines&#xff08;2&#xff09;Android Studio下载的 Java JDK /Users/用户名/Library/Java/JavaVirtualMachines2、Android SDK 目录 /Users/用户名/Libr…

ansible处理多台机器部署基础环境

本次以多台机器需部署zabbix客户端为例&#xff1a; 机器先做免密互信&#xff0c;ansible主机上执行ssh-keygen,一路回车&#xff0c;然后将公钥发送给需管理的主机&#xff1a; ssh-copy-id rootIP 1、编辑hosts文件&#xff0c;添加需配置的主机IP&#xff0c;并测试连通…

Android10.0 SystemUI 下拉通知栏去掉左右滑动菜单

1.前言 在10.0的系统产品定制化开发中,在systemui的下拉状态栏部分,包括qspanel部分和通知栏部分,而在下拉通知栏的相关事件中, 通知栏左滑右滑都可以设置按钮等 来跳转到系统设置页面,所以产品开发需要,要求去掉通知栏通知左右滑动显示系统设置图标功能 禁止进入到系统…

Opencv(C++)学习 TBB与OPENMP的加速效果实验与ARM上的实践

背景&#xff1a;在某个嵌入式上的图像处理项目功能开发告一段落&#xff0c;进入性能优化阶段。尝试从多线程上对图像处理过程进行加速。经过初步调研后&#xff0c;可以从OPENMP&#xff0c;TBB这两块进行加速&#xff0c;当前项目中有些算法已采用多线程加速&#xff0c;这次…

FRDM‐K64F开发板 ARM Mbed 在线编译器嵌入式和物联网开发

传感器和执行器 传感器是将物理参数转换为电输出的设备。 传感器是换能器的一种。 传感器可分为模拟传感器和数字传感器。 模拟传感器以电压和电流的形式提供输出。 微控制器需要 ADC&#xff08;模数转换器&#xff09;读取来自模拟传感器的数据。 许多较新的传感器都是数字传…

僵尸进程以及解决办法、僵死进程有什么区别?

僵尸进程是指已经结束但父进程没有回收它的资源的进程。它们在进程表中仍占有一个位置&#xff0c;但不能被调度运行。僵尸进程会浪费系统的资源&#xff0c;如果过多&#xff0c;可能导致系统无法创建新的进程。僵尸进程的产生原因是父进程没有及时调用 wait 或 waitpid 函数来…

【蓝桥杯冲冲冲】[NOIP2000 提高组] 方格取数

蓝桥杯备赛 | 洛谷做题打卡day19 文章目录 蓝桥杯备赛 | 洛谷做题打卡day19[NOIP2000 提高组] 方格取数题目背景题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示题解代码我的一些话 [NOIP2000 提高组] 方格取数 题目背景 NOIP 2000 提高组 T4 题目描述 设有 N N…

如何用甘特图跟踪项目进度

甘特图是一个简单但是极其强大的项目管理工具,能够清晰可视化复杂项目的进度,在项目跟踪和控制上发挥重要作用。任何一个严肃的项目组织者都会使用甘特图来规划和管理项目中的任务。 甘特图的纵坐标表示项目的各项活动或任务,横坐标表示项目的时间进度。每个任务用一条横条表示…

Java【代码 16】将word、excel文件转换为pdf格式和将pdf文档转换为image格式工具类分享(Gitee源码)aspose转换中文乱码问题处理

word、excel、pdf、image转换工具类 1.感谢2.包含的工具类3.lib文件说明3.1 使用的3.2 未使用的 4.核心代码4.1 WordToPdfUtil4.2 ExcelToPdfUtil4.3 PdfToImageUtil 6.问题处理6.1 Word中文无法转换6.2 Excel中文无法转换 7.总结 1.感谢 感谢小伙伴儿的分享&#xff1a; ● 不…

使用vs2022将.net8的应用程序发布为一个单独文件

在使用.NetCore3.1时&#xff0c;可以通过设置以下工程配置文本来将项目发布为一个单独的应用程序文件&#xff1a; <Project Sdk"Microsoft.NET.Sdk.WindowsDesktop"><PropertyGroup><TargetFramework>netcoreapp3.1</TargetFramework><…

permanent property翻译为永久产权属于错误,应该是正式产权、法定产权

很多人说美国房子是永久产权。再配上“风能进&#xff0c;雨能进&#xff0c;国王不能进”&#xff0c;于是给人一种误解&#xff0c;就是永远所有。现实性是什么呢&#xff1f;你今天不交房产税、物业费&#xff0c;明天就被拍卖。这就是所谓的永久产权&#xff1f;显然不是。…

MySQL新类型JSON的用法讲解

前言 MySQL相信大家应该不陌生吧&#xff0c;都知道MySQL有很多数据类型&#xff0c;包括int&#xff0c;char&#xff0c;verchar&#xff0c;这些也是平时建表使用比较多的类型&#xff0c;在MySQL 8引入了新的数据类型——JSON&#xff0c;它使得在数据库中存储和查询 JSON…

QT容器分类与QSet应用

一.QT容器分类 Qt提供了多种容器类&#xff0c;大致可以分为以下几类&#xff1a; 1.顺序容器&#xff1a;这类容器按照线性顺序&#xff08;如列表或数组&#xff09;存储元素。例如&#xff0c;QList, QLinkedList, QVector, QStack, 和 QQueue。 2.关联容器&#xff1a;这…

LLM应用开发与落地:基于上下文的文本信息检测与提取

最近一直用LLM解决各种各样的问题&#xff0c;感觉已经脱离不了LLM了。每次使用LLM解决一个之前解决不了的问题&#xff0c;或者大大提升我的工作效率的时候&#xff0c;我内心都小小会激动一下。我想这是只通过看文章或只是研究AI理论感受不到的小确幸。我也因此更加确信LLM是…

react-jss书写样式

目录 react-jss的使用 react-jss的使用 实现组件化样式、动态样式、避免样式冲突 npm install react-jss yarn add react-jss// 使用 import React from react; import { createUseStyles } from react-jss;const useStyles createUseStyles({myButton: {color: green,margi…

Kotlin MultiPlatform:构建跨平台应用的未来

Kotlin MultiPlatform&#xff1a;构建跨平台应用的未来 1 引言 1.1 Kotlin MultiPlatform简介 Kotlin MultiPlatform&#xff08;简称KMP&#xff09;是一种由JetBrains开发的跨平台开发解决方案&#xff0c;它建立在Kotlin语言之上。KMP允许开发者使用一套Kotlin代码来构建…