java【链表实现】

本贴最后更新于 1303 天前,其中的信息可能已经时过境迁

一般我们在学习集合之前,都会去了解了解数据结构的相关知识,最常见的莫过于链表,在 List 集合里面,linkedList 这个子类就是使用的链表的数据结果进行实现的,

链表的优势:新增数据,删除数据,会很容易

动态数组优势:检索快

下面的有一个关于链表的数据结构,是我大学学习期间写的一个测试,便于我们加深对链表结构的掌握。

package ITaljavaT3;

import org.junit.jupiter.api.Test;

/*
 * 链表的的增加
 */
interface Ilink<E>{
	public abstract void add(E date);//进行元素的添加
	public abstract int size();//进行长度的的获取
	public abstract boolean isEmpty();//进行判断是否为空集合
	public abstract Object[] toArray();//根据元素集合对应给数组获取数据
	public abstract E getdate (int index);//根据指定出的索引获取数据
	public abstract void setdate(int index,E date);//修改指定处索引处的值
	public abstract boolean judge(E date);//判断链表中数据是否存在
	public abstract void removedate(E date);//进行数据的删除
	public abstract void clean();//清空集合数据
}
class impLink<E> implements Ilink<E>{

	/**
	 * 节点内部类
	 * @author 米饭饭一族
	 *
	 */
	private class Node{
		/**
		 * 内部类成员变量
		 */
		private E date;
	
		private Node next;
	
		public Node(E date) {
			this.date = date;
		}
		//第一次调用;this=impLink.root
		//第二次调用;this=impLink.root.next
		//第三次调用;this=impLink.root.next.next
		public void addnode(Node newnode) {//保存新的NODE数据
			if(this.next == null) {//当前节点的下一个节点为null,
				this.next = newnode;//保存当前节点
			}else {
				/*
				 * 在第一次循环中这个地方this是 impLink.root
				 * 第二次的时候就是implink.root.next.addnode(newnode);
				 * 第三次的时候就是implink.root.next.next.addnode(newnode);
				 */
				this.next.addnode(newnode);//将这个节点(newnode)添加到上一个数据的节点中,
			}
		}
		//第一次调用 this=implink.root;根节点
		//第二次调用 this=implink.root.next;根节点
		//第一三调用 this=implink.root.next.next;根节点
		public void returndate() {
			//外部类的中当前对象
			impLink.this.returndate[impLink.this.foot ++]=this.date;
			if(this.next!=null) {
				this.next.returndate();//递归中出口
			}
		}
		//根据索引获取相应的数据
		public E getNode(int index) {
			if(impLink.this.foot++==index) {
				return this.date;
			}
			return this.next.getNode(index);
		}
	
		//根据索引修改相应的数据
		public void setNode(int index,E date ) {
			if(impLink.this.foot++ ==index) {
				this.date=date;
			}else {
				this.next.setNode(index,date);
			}
		}
		//判断date数据是否存在
		public boolean judgeNode(E date) {
			if(date.equals(this.date)) {
				return true;
			}else {
				if(this.next==null) {
					return false;
				}else {
					return this.next.judgeNode(date);
				}
			}	
		}
		//进行数据的删除(把节点的下一个节点赋值给节点的上一个节点)
		public void removeNode(Node before,E date) {
			if(date.equals(this.date)) {
				before.next=this.next;
			}else {
				this.next.removeNode(this, date);
			}
		}
	
	}
	//------------------------linK类的成员变量-----------------
	private Node root;//保存根元素
	private int count;
	private int foot;
	private Object[] returndate;
	//------------------------linK类的成员方法-----------------
	//Node node=this.root;
	@Override
	public void add(E date) {
		if(date==null) {//保存数据为空
			return;//方法调用直接返回
		}
		//date是一个数据,数据本身是没,要想实现关联性就必须使用Node来实现引用之间的 传递
		Node newnode = new Node(date);//创建一个新的节点
		if(this.root==null) {//根节点为空
			this.root = newnode;//将newnode设定为根节点
		}else {//节点存在
			this.root.addnode(newnode);//将新的节点保存在合适的位置
			//this.root为跟节点,跟节点调用方法
		}
		this.count++;
	
	}
	//进行长度的的获取
	public int size() {
		return this.count;
	}
	//进行判断是否为空集合
	public boolean isEmpty() {
		return this.count==0;
		//return this.root==null;
	}
	//数据的返回
	public Object[] toArray() {
		//先判断是否为空
		if(this.isEmpty()) {
			return null;
		}
		this.foot=0;
		this.returndate = new Object[this.count];
		//用node类去获取数据
		this.root.returndate();
		return this.returndate;
	}
	//根据索引获取指定的数据
	public E getdate(int index) {
		if(index>=count) {
			return null;		
		}
		this.foot=0;
		return this.root.getNode(index);
	}
	//修改指定处的数据
	public void setdate(int index,E date) {
		if(index >= count) {
			return;
		}else {
			this.foot=0;
			this.root.setNode(index, date);
		}
	}
	//判断数据是否存在
	public boolean judge(E date) {
		if(date == null) {
			return false;
		}
		return this.root.judgeNode(date);
	}
	//进行数据的删除
	public void removedate(E date) {
		if(this.judge(date)) {//判断date是否存在
			if(date.equals(this.root.date)) {
				this.root = this.root.next;
			}else {
				this.root.removeNode(this.root, date);
			}
			this.count--;
		}
	}
	//进行集合的清理
	public void clean() {
		this.root = null;//根节点为空
		this.count = 0;//索引清除
	}

}
public class datascope {
	
	/**
	 * 链表结构的测试操作
	 */
	@Test
	public void testdataScope() {
	
			Ilink<String> link = new impLink<String>();
		
			System.out.println(String.format("开始  【长度】%s,【值】%s,【是否为空】%s", link.size(),link.toString(),link.isEmpty()));
			link.add("第一个");
			link.add("第二个");
			link.add("第三个");
			link.add("第四个");
			link.add("第五个");
			System.out.println(String.format("中间 【长度】%s,【值】%s,【是否为空】%s", link.size(),link.toString(),link.isEmpty()));
			//删除一个节点
			link.removedate("第一个");
			link.setdate(3, "修改第三个数据成功");
			//进行数据清空
			System.out.println(String.format("修改 【长度】%s,【值】%s,【是否为空】%s", link.size(),link.toString(),link.isEmpty()));
		
			link.clean();
		
			System.out.println(String.format("结束 【长度】%s,【值】%s,【是否为空】%s", link.size(),link.toString(),link.isEmpty()));
		
			Object[] result = link.toArray();
			if(result!=null) {
				for(Object temp:result) {
					System.out.println(temp);
				}
			}
			System.out.println("----------------指定数据的获取(索引)---------------");
			if(!link.isEmpty()) {
				System.out.println(link.getdate(1));
				System.out.println(link.getdate(2));
				System.out.println(link.getdate(3));
				System.out.println(link.getdate(19)); 
			}
			System.out.println("----------------判断数据是否存在)---------------");
			if(!link.isEmpty()) {
				System.out.println(link.judge("第一个"));
				System.out.println(link.judge("aaa"));
			}
		
		}

}

将上述的链表进行扩展,实现一个购物车,写一个购物车的实体类小 demo

package ITaljavaT4;
/*
 * 链表的的增加
 */
interface Ilink<E>{
	public abstract void add(E date);//进行元素的添加
	public abstract int size();//进行长度的的获取
	public abstract boolean isEmpty();//进行判断是否为空集合
	public abstract Object[] toArray();//根据元素集合对应给数组获取数据
	public abstract E getdate (int index);//根据指定出的索引获取数据
	public abstract void setdate(int index,E date);//修改指定处索引处的值
	public abstract boolean judge(E date);//判断链表中数据是否存在
	public abstract void removedate(E date);//进行数据的删除
	public abstract void clean();//清空集合数据
}
class impLink<E> implements Ilink<E>{
	private class Node{
		private E date;
		private Node next;
		public Node(E date) {
			this.date=date;
		}
		//第一次调用;this=impLink.root
		//第二次调用;this=impLink.root.next
		//第三次调用;this=impLink.root.next.next
		public void addnode(Node newnode) {//保存新的NODE数据
			if(this.next==null) {//当前节点的下一个节点为null,
				this.next=newnode;//保存当前节点
			}else {
				/*
				 * 在第一次循环中这个地方this是 impLink.root
				 * 第二次的时候就是implink.root.next.addnode(newnode);
				 * 第三次的时候就是implink.root.next.next.addnode(newnode);
				 * 
				 */
				this.next.addnode(newnode);//将这个节点(newnode)添加到上一个数据的节点中,
			}
		}
		//第一次调用 this=implink.root;根节点
		//第二次调用 this=implink.root.next;根节点
		//第一三调用 this=implink.root.next.next;根节点
		public void returndate() {
			//外部类的中当前对象
			impLink.this.returndate[impLink.this.foot ++]=this.date;
			if(this.next!=null) {
				this.next.returndate();//递归中出口
			}
		}
		//根据索引获取相应的数据
		public E getNode(int index) {
			if(impLink.this.foot++==index) {
				return this.date;
			}
			return this.next.getNode(index);
		}
	
		//根据索引修改相应的数据
		public void setNode(int index,E date ) {
			if(impLink.this.foot++ ==index) {
				this.date=date;
			}else {
				this.next.setNode(index,date);
			}
		}
		//判断date数据是否存在
		public boolean judgeNode(E date) {
			if(date.equals(this.date)) {
				return true;
			}else {
				if(this.next==null) {
					return false;
				}else {
					return this.next.judgeNode(date);
				}
			}	
		}
		//进行数据的删除(把节点的下一个节点赋值给节点的上一个节点)
		public void removeNode(Node before,E date) {
			if(date.equals(this.date)) {
				before.next=this.next;
			}else {
				this.next.removeNode(this, date);
			}
		}
	
	}
	//------------------------linK类的成员变量-----------------
	private Node root;//保存根元素
	private int count;
	private int foot;
	private Object[] returndate;
	//------------------------linK类的成员方法-----------------
	//Node node=this.root;
	@Override
	public void add(E date) {
		if(date==null) {//保存数据为空
			return;//方法调用直接返回
		}
		//date是一个数据,数据本身是没,要想实现关联性就必须使用Node来实现引用之间的 传递
		Node newnode=new Node(date);//创建一个新的节点
		if(this.root==null) {//根节点为空
			this.root=newnode;//将newnode设定为根节点
		}else {//节点存在
			this.root.addnode(newnode);//将新的节点保存在合适的位置
			//this.root为跟节点,跟节点调用方法
		}
		this.count++;
	
	}
	//进行长度的的获取
	public int size() {
		return this.count;
	}
	//进行判断是否为空集合
	public boolean isEmpty() {
		return this.count==0;
		//return this.root==null;
	}
	//数据的返回
	public Object[] toArray() {
		//先判断是否为空
		if(this.isEmpty()) {
			return null;
		}
		this.foot=0;
		this.returndate=new Object[this.count];
		//用node类去获取数据
		this.root.returndate();
		return this.returndate;
	}
	//根据索引获取指定的数据
	public E getdate(int index) {
		if(index>=count) {
			return null;		
		}
		this.foot=0;
		return this.root.getNode(index);
	}
	//修改指定处的数据
	public void setdate(int index,E date) {
		if(index>=count) {
			return;
		}else {
			this.foot=0;
			this.root.setNode(index, date);
		}
	}
	//判断数据是否存在
	public boolean judge(E date) {
		if(date==null) {
			return false;
		}
		return this.root.judgeNode(date);
	}
	//进行数据的删除
	public void removedate(E date) {
		if(this.judge(date)) {//判断date是否存在
			if(date.equals(this.root.date)) {
				this.root=this.root.next;
			}else {
				this.root.removeNode(this.root, date);
			}
			this.count--;
		}
	}
	//进行集合的清理
	public void clean() {
		this.root=null;//根节点为空
		this.count=0;//索引清除
	}

}
/*
 * 写一个购物车的实现
 * 1.收银台
 *  包括一个计算总价的方法,一个获取商品商品数量的方法
 * 2.购物车的接口标准
 * 包括一个 添加商品,包括删除商品,包括获取所有的商品
 * 3.商品类
 * 包括一个商品的价格,名字
 */
//商品标准
interface Igoods{
	public String getName();
	public double getprice();
}
//购物车的标准
interface IShop{//购物车的接口
	public void addshop(Igoods goods);
	public void delete(Igoods goods);
	public Object[] getall();
}
class Shop implements IShop{
	private Igoods goods;
	private Ilink<Igoods> shopgoogs =new impLink<Igoods>();
//	public Shop(Igoods goods) {
//		this.goods=goods;
//	}
	@Override
	//添加商品
	public void addshop(Igoods goods) {
		// TODO Auto-generated method stub
		this.shopgoogs.add(goods);
	}

	@Override
	//删除商品
	public void delete(Igoods goods) {
		// TODO Auto-generated method stub
		this.shopgoogs.removedate(goods);
	}

	@Override
	//获取所有的商品
	public Object[] getall() {
		// TODO Auto-generated method stub
	return this.shopgoogs.toArray();
	}

}
class bag implements Igoods{
	private String name;
	private double price;
	public bag(String name,double price ) {
		this.name=name;
		this.price=price;
	}
	@Override
	public String getName() {
		// TODO Auto-generated method stub
		return this.name;
	}

	@Override
	public double getprice() {
		// TODO Auto-generated method stub
		return this.price;
	}
	public String toString() {
		return "[商品信息:]"+this.name+" -- "+"[商品的价格:]"+this.price;
	}
	public boolean equals(Object obj) {
		if(obj==null) {
			return false;
		}
		if(!(obj instanceof bag)) {
			return false;
		}
		if(obj==this) {
			return true; 
		}
		bag other=(bag)obj;
		return this.name.equals(other.name) && this.price==other.price;
	} 
}
class book implements Igoods{
	private String name;
	private double price;
	public book(String name,double price ) {
		this.name=name;
		this.price=price;
	}
	@Override
	public String getName() {
		// TODO Auto-generated method stub
		return this.name;
	}

	@Override
	public double getprice() {
		// TODO Auto-generated method stub
		return this.price;
	}
	public String toString() {
		return "[商品信息:]"+this.name+" -- "+"[商品的价格:]"+this.price;
	}
	public boolean equals(Object obj) {
		if(obj==null) {
			return false;
		}
		if(!(obj instanceof book)) {
			return false;
		}
		if(obj==this) {
			return true; 
		}
		book other=(book)obj;
		return this.name.equals(other.name) && this.price==other.price;
	} 
}
//收银台
class Cashier{
	//结算总的价钱
	public double allprice(IShop shop) {
		double allprice=0.0;
		Object obj[]=shop.getall();
		for(Object temp:obj) {
			Igoods goods=(Igoods)temp;
			allprice+=goods.getprice();
		}
		return allprice;
	}
	//结算商品的总数
	public int allcount(IShop shop) {
		return shop.getall().length;
	}
}

	public class ITaljava01 {
		public static void main(String[] args) {
		//添加商品
		IShop shop =new Shop();
		shop.addshop(new bag("超级书包",18.9));
		shop.addshop(new bag("中级书包",18.9));
		shop.addshop(new bag("低级书包",11.9));
		shop.addshop(new bag("低级书包",11.9));
		shop.addshop(new book("c++",19.9));
		shop.addshop(new book("java",88.9));
		//所有的信息
		Object object1[] =shop.getall();
		for(Object temp: object1) {
			System.out.println(temp);
		}
		//删除一个信息
		shop.delete(new bag("低级书包",11.9));
		//在此过去所有的删除以后的数据
		System.out.println("---------删除以后获取数据--------------");
		Object object2[] =shop.getall();
		for(Object temp: object2) {
			System.out.println(temp);
		}
		System.out.println("--------计算购物车里面的价钱---------------");
		Cashier cas=new Cashier();
		System.out.println(cas.allprice(shop));
		System.out.println(cas.allcount(shop));
		}
}

有兴趣的可以分析一下代码,也比较简单,主要是理解集合里面的一些数据结构。

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8213 回帖
  • 链表
    12 引用 • 6 回帖
  • 数据结构
    88 引用 • 115 回帖 • 4 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 476 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 355 关注
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 664 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖 • 2 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1348 回帖
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    166 引用 • 595 回帖 • 1 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    209 引用 • 2031 回帖
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    47 引用 • 25 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    729 引用 • 1327 回帖
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 588 回帖
  • BookxNote

    BookxNote 是一款全新的电子书学习工具,助力您的学习与思考,让您的大脑更高效的记忆。

    笔记整理交给我,一心只读圣贤书。

    1 引用 • 1 回帖
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    6 引用 • 15 回帖 • 113 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 642 关注
  • 倾城之链
    23 引用 • 66 回帖 • 137 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 1 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 733 关注
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 530 关注
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 1 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    167 引用 • 1513 回帖 • 1 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 709 关注
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    12 引用 • 54 回帖 • 164 关注
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    944 引用 • 943 回帖
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 134 关注
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖 • 2 关注
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    66 引用 • 114 回帖 • 228 关注