3、循环链表(java实现)
1、节点类
public class Node<T> {
public T data;
public Node next;
}
2、实现类
public class CircularLink<T> {
private static Node head = null;
/**
* 初始化
*/
public void initCircularLink() {
head = new Node();
head.data = null;
head.next = head;
}
/**
* 插入节点
*
* @param element :节点元素值
*/
public void insertCircularLink(T element) {
Node node = new Node(); //初始化节点
node.data = element;
if (head.next == head) {
head.next = node;
node.next = head;
} else {
Node temp = head;
while (temp.next != head) {
temp = temp.next;
}
temp.next = node;
node.next = head;
}
}
/**
* 值删除
*
* @param element : 要删除的值
* @return :删除则为true 否则为假
*/
public boolean deleteCircularLink(T element) {
Node temp = head;
if (temp.next == head) {
System.out.println("链表已空,没有可删除的值");
return false;
}
while (temp.next != head) {
if (temp.next.data == element) {
temp.next = temp.next.next;
return true;
} else {
temp = temp.next;
}
}
return false;
}
/**
* 下标删除
*
* @param i : 要删除的值下标
* @return :删除则为true 否则为假
*/
public boolean deleteIndexCircularLink(int i) {
Node temp = head;
int index = -1;
if (temp.next == head) {
System.out.println("链表已空,没有可删除的值");
return false;
}
if (i < 0 || i >= sizeCircularLink()) {
System.out.println("越界下标");
return false;
}
while (temp.next != head) {
index++;
if (index == i) {
temp.next = temp.next.next;
}
temp = temp.next;
}
return false;
}
/**
* 给定值求下标
*
* @param element :要找的元素
*/
public void findCircularLink(T element) {
Node temp = head;
int index = -1;
if (temp.next == head) {
System.out.println("链表已空,无法查找");
}
while (temp.next != head) {
temp = temp.next;
index++;
if (temp.data == element) {
temp = temp.next;
System.out.println("下标为: " + index);
return;
}
}
System.out.println("你要找的值不在这里");
}
/**
* 下标求值
* @param index
*/
public void findDataCircularLink(int index) {
Node temp = head;
int size= 0; //为增加下标用的
if (temp.next == head) {
System.out.println("链表已空,没有可删除的值");
return;
}
if (index >= sizeCircularLink() || index < 0){
System.out.println("你的下标越界");
return;
}
while (temp.next !=head){
temp = temp.next;
if (size == index){
System.out.println("你要找的值为: "+temp.data);
return;
}
size++;
}
System.out.println("没有你的值");
}
/**
* 打印
*/
public void printCircularLink() {
Node temp = head;
System.out.print("打印循环链表: ");
while (temp.next != head) {
temp = temp.next;
System.out.print(temp.data + " ");
}
System.out.println();
}
/**
* 求长度
*
* @return : 返回的长度
*/
public static int sizeCircularLink() {
Node temp = head;
int size = 0;
while (temp.next != head) {
temp = temp.next;
size++;
}
return size;
}
public static void main(String[] args) {
CircularLink<Integer> circularLink = new CircularLink();
circularLink.initCircularLink();
circularLink.insertCircularLink(1);
circularLink.insertCircularLink(2);
circularLink.insertCircularLink(3);
circularLink.insertCircularLink(4);
circularLink.insertCircularLink(5);
circularLink.printCircularLink();
System.out.println("长度: " + circularLink.sizeCircularLink());
System.out.println();
System.out.println("值删除值");
circularLink.deleteCircularLink(1);
circularLink.printCircularLink();
System.out.println("长度: " + circularLink.sizeCircularLink());
System.out.println();
System.out.println("下标删除值");
circularLink.deleteIndexCircularLink(1);
circularLink.printCircularLink();
System.out.println("长度: " + circularLink.sizeCircularLink());
System.out.println();
System.out.println("值查找下标");
circularLink.findCircularLink(5);
circularLink.printCircularLink();
System.out.println("长度: " + circularLink.sizeCircularLink());
System.out.println();
System.out.println("下标查找值");
circularLink.findDataCircularLink(3);
circularLink.printCircularLink();
System.out.println("长度: " + circularLink.sizeCircularLink());
System.out.println();
}
}
3、测试结果
打印循环链表: 1 2 3 4 5
长度: 5 值删除值
打印循环链表: 2 3 4 5
长度: 4 下标删除值
打印循环链表: 2 4 5
长度: 3 值查找下标
下标为: 2
打印循环链表: 2 4 5
长度: 3 下标查找值
你的下标越界
打印循环链表: 2 4 5
长度: 3
3、循环链表(java实现)的更多相关文章
- java与数据结构(4)---java实现双向循环链表
线性表之链式存储结构双向循环链表 双向循环链表:每个结点包含了数据.直接前驱地址指针和直接后驱地址指针,头结点的直接前驱指向尾结点,尾结点的直接后驱指向头结点,头尾相连构成一个可正可反的圆环.可以形象 ...
- Spark案例分析
一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...
- java程序设计之循环链表
照例来说点废话,愿自己生一颗温柔细腻的心,这样女朋友也许一个眼神,一个微笑,我就知道如何做,可惜内心与外表一样粗糙,这一生有幸认识她,愿天下有情人终成眷属. 循环链表,顾名思义循环就好了,所以建一个线 ...
- JAVA 链表操作:循环链表
主要分析示例: 一.循环链表简述 二.单链表循环链表 三.双链表循环链表 一.循环链表简述 循环链表即链表形成了一个循环的结构,尾节点不再指向NULL,而是指向头节点HEAD,此时判定链表的结束是尾节 ...
- 双向循环链表的Java版本实现
1.单项循环列表 单向循环链表是单链表的另一种形式,其结构特点是链表中最后一个结点的指针不再是结束标记,而是指向整个链表的第一个结点,从而使单链表形成一个环.和单链表相比,循环单链表的长处是从链尾到链 ...
- java与数据结构(3)---java实现循环链表
循环链表:将单链表中尾结点的指针由空指针改为指向头结点,就使整个单链表形成一个环,这种首尾相接的单链表称为单链表循环表,即循环链表. 循环链表与单链表最重要的区别是:尾结点的指针,不再是p->n ...
- java实现循环链表的增删功能
java实现循环链表的增删功能,完整代码 package songyan.test.demo; public class Demo { // java 实现循环链表 public static voi ...
- 【Java】 大话数据结构(4) 线性表之循环链表
本文稍微介绍了一下循环链表. 将单链表终端结点的指针域由空指针改为指向头结点,形成一个环,这种头尾相接的单链表称为循环列表. 循环列表的结构如下图所示: 循环链表的优点:可以从任意一个结点出发,遍历所 ...
- java实现双向循环链表
java实现循环链表:http://www.cnblogs.com/lixiaolun/p/4643911.html 在单链表中,查询下一个元素的时间是O(1).查询上一个元素的时间却是O(n). 为 ...
- (java实现)单向循环链表
什么是单向循环链表 单向循环链表基本与单向链表相同,唯一的区别就是单向循环链表的尾节点指向的不是null,而是头节点(注意:不是头指针). 因此,单向循环链表的任何节点的下一部分都不存在NULL值. ...
随机推荐
- bootstrap实战练习中涉及的知识点(很有用哦!)
看的有关视频做的笔记,对bootstrap中涉及的知识点做了一定的解析,很有用哦!(新手上路,有不合适的地方可以指出哦!) 下面进入正题: Bootstrap是当下最流行的前端框架(界面工具集) 特点 ...
- React预备知识点
1.react中的状态提升 react的状态提升就是用户对子组件操作,子组件不改变自己的状态,而是通过自己的props把操作改变的数据传递给父组件,改变父组件的状态,从而改变受父组件控制的所有子组件的 ...
- 开源音乐下载神器XMusicDownloader更新,支持歌单一键下载,支持无损音乐
开源音乐下载神器XMusicDownloader更新啦,新增网易.腾讯音乐歌单歌曲.歌手歌曲.专辑歌曲一键下载,同时支持下载flac无损音乐. 功能 V1.0 功能开源工具软件XMusicDownlo ...
- python+appium自动化测试(一)-----环境搭建
基础背景: windows7系统 +python3.4版本 环境搭建目标: 使用python编写app自动化测试脚本并成功执行. 搭建步骤: 1.安装python3,安装步骤详见:https:// ...
- notepad 写html乱码,已解决
写一些简单基础的html文件时,突然发现新建的demo2,在浏览器打开乱码,而昨天的demo1打开没乱码,真奇怪,开始排查原因. 1.检查代码,,设了charset=UTF-8,看不出毛病. 2.索性 ...
- 合并多个jar包,并通过私服依赖
背景:许多jar包在maven仓库中没有,项目如果添加了许多的本地jar包,别人拿到代码也无法编译 需求:将本地jar包上传至私服并设置依赖,如果jar包较多,但都从属于同一功能,需要合并为一个jar ...
- 2019heox博客部署到coding该绕的坑-奥怪的小栈
文章转载于:2019heox博客部署到coding该绕的坑-奥怪的小栈 这篇文章适用于初次部署和部署到github后想双线部署到coding的朋友们,我将带你们绕过一些我踏过的坑. 前言 我一开始没打 ...
- Linux环境搭建 | 手把手教你配置Linux虚拟机
在上一节 「手把你教你安装Linux虚拟机」 里,我们已经安装好了Linux虚拟机,在这一节里,我们将配置安装好的Linux虚拟机,使其达到可以开发的程度. Ubuntu刚安装完毕之后,还无法进行开发 ...
- 代码解读 | VINS 视觉前端
本文作者是计算机视觉life公众号成员蔡量力,由于格式问题部分内容显示可能有问题,更好的阅读体验,请查看原文链接:代码解读 | VINS 视觉前端 vins前端概述 在搞清楚VINS前端之前,首先要搞 ...
- 数据库回滚(rollback)和撤销(undo)的区别
数据库回滚(rollback)和撤销(undo)的区别就是把某一个数据库操作恢复到该操作之前的状态,下面结合自己理解总结一下区别,如有错误,欢迎各路大佬斧正: 数据库事务过程:执行SQL——提交 ...