java实现单链表的增删改以及排序
使用java代码模拟单链表的增删改以及排序功能
代码如下:
package com.seizedays.linked_list;
public class SingleLinkedListDemo {// 主方法
public static void main(String[] args) {
HeroNode node1 = new HeroNode(1, "宋江", "及时雨");
HeroNode node2 = new HeroNode(2, "卢俊义", "玉麒麟");
HeroNode node3 = new HeroNode(3, "吴用", "智多星");
HeroNode node4 = new HeroNode(4, "林冲", "豹子头");
HeroNode node5 = new HeroNode(3, "李逵", "黑旋风");
SingleLinkedList list = new SingleLinkedList();
// list.add(node1);
// list.add(node2);
// list.add(node3);
list.addByOrder(node1);
list.addByOrder(node3);
// list.addByOrder(node5);
list.update(node5);
list.addByOrder(node2);
list.addByOrder(node4);
list.delete(5);
list.showList();
}
}
//定义SingleLinkedList管理结点
class SingleLinkedList {
//先初始化一个头节点,头节点不动 不存放数据
private HeroNode head = new HeroNode(0, "", "");
//1.添加节点到单向列表
// 不考虑编号顺序时候 将最后节点的next指向新的节点
public void add(HeroNode heroNode) {
//temp用于辅助遍历
HeroNode temp = head;
//找到最后
while (temp.next != null) {
//找到链表的最后 跳出
temp = temp.next;
}
//当退出while循环时候 temp指向链表的最后
temp.next = heroNode;
}
// 2.按照编号大小有规律地将节点插入链表
public void addByOrder(HeroNode heroNode) {
//通过辅助节点遍历来找到添加的位置
HeroNode temp = head;
while (temp.next != null) {
if (heroNode.no == temp.next.no){
System.out.printf("编号%d已经存在,不能加入\n", heroNode.no);
return;
}
if (heroNode.no < temp.next.no) {
heroNode.next = temp.next;
temp.next = heroNode;
return;
}
temp = temp.next;
}
temp.next = heroNode;
}
//3.根据编号来修改节点的信息
//根据newNode的no来修改节点
public void update(HeroNode newNode){
if (head.next == null){
System.out.println("链表为空");
return;
}
HeroNode temp = head;
while (temp.next != null){
if (temp.next.no == newNode.no){
newNode.next = temp.next.next;
temp.next = newNode;
break;
}
temp = temp.next;
}
}
//4.删除节点
public void delete(int no){
if (head.next == null){
System.out.println("链表为空 删除失败");
return;
}
HeroNode temp = head;
while (temp.next != null){
if (temp.next.no == no){
temp.next = temp.next.next;
System.out.println("删除完成");
return;
}
temp = temp.next;
}
System.out.println("没有找到对应节点,删除失败");
}
// 显示链表
public void showList() {
if (head.next == null) {
System.out.println("链表为空");
return;
}
//head不能动 用辅助变量来遍历
HeroNode temp = head.next;
while (temp != null) {
//输出节点信息
System.out.println(temp);
//节点后移
temp = temp.next;
}
}
}
//定义头结点
class HeroNode {
public int no;
public String name;
public String nickname;
public HeroNode next; //指向下一个结点
public HeroNode(int no, String name, String nickname) {
this.no = no;
this.name = name;
this.nickname = nickname;
}
@Override
public String toString() {
return "HeroNode{" +
"no=" + no +
", name='" + name + '\'' +
", nickname='" + nickname + '\'' +
'}';
}
}
java实现单链表的增删改以及排序的更多相关文章
- 关于单链表的增删改查方法的递归实现(JAVA语言实现)
因为在学习数据结构,准备把java的集合框架底层源码,好好的过一遍,所以先按照自己的想法把单链表的类给写出来了; 写该类的目的: 1.练习递归 2.为深入理解java集合框架底层源码打好基础 学习的视 ...
- 史上最全单链表的增删改查反转等操作汇总以及5种排序算法(C语言)
目录 1.准备工作 2.创建链表 3.打印链表 4.在元素后面插入元素 5.在元素前面增加元素 6.删除链表元素,要注意删除链表尾还是链表头 7.根据传入的数值查询链表 8.修改链表元素 9.求链表长 ...
- Java实现单向链表的增删改查
class List<T> { private class Node { private T data; private Node next; private Node(T data) { ...
- java实战应用:MyBatis实现单表的增删改
MyBatis 是支持普通 SQL查询.存储过程和高级映射的优秀持久层框架.MyBatis 消除了差点儿全部的JDBC代码和參数的手工设置以及结果集的检索.MyBatis 使用简单的 XML或注解用于 ...
- 2.Mybatis入门程序(单表的增删改成)
这里讲的单表的增删改查,是由mapper代理的增删改查,先来看看步骤: 1.jar包的导入 2.配置全局的配置文件 3.建立接口 4.编写mapper.xml 5.测试 工程结构:这个你们自己可以调整 ...
- Java实现单链表的各种操作
Java实现单链表的各种操作 主要内容:1.单链表的基本操作 2.删除重复数据 3.找到倒数第k个元素 4.实现链表的反转 5.从尾到头输出链表 6.找到中间节点 7.检测链表是否有环 8.在 ...
- java对xml文件做增删改查------摘录
java对xml文件做增删改查 package com.wss; import java.io.File;import java.util.ArrayList;import java.util.Lis ...
- 使用java对sql server进行增删改查
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...
- java实现单链表的增删功能
JAVA 实现单链表的增删功能 package linked; class LinkedTable{ } public class LinkedTableTest { public static vo ...
随机推荐
- 二分查找法demo
正文 中午闲着有点时间,做个demo睡觉去,这个例子网上应该都有,自己只是敲一下给自己做个记录. public static void main(String[] args) { int[] whit ...
- C#数据结构与算法系列(十九):选择排序算法(SelectSort)
1.介绍 选择排序算法属于内部排序算法,是从欲排序的数据中,按指定的规则选出某一元素,再依规定交换位置达到排序的目的 时间复杂度:O(n^2) 双层for 2.思想 选择排序(select sorti ...
- 写给程序员的机器学习入门 (七) - 双向递归模型 (BRNN) - 根据上下文补全单词
这一篇将会介绍什么是双向递归模型和如何使用双向递归模型实现根据上下文补全句子中的单词. 双向递归模型 到这里为止我们看到的例子都是按原有顺序把输入传给递归模型的,例如传递第一天股价会返回根据第一天股价 ...
- 对于python 作用域新的理解
今天看Python习题,看到如下题目 def num(): return [lambda x: i*x for i in range(4)] print([m(2) for m in num()]) ...
- 【Python3爬虫】破解时光网登录加密参数并实现模拟登录
一.站点分析 MTime 时光网是一个电影媒体与电商服务平台,而这次做的模拟登录则是依靠其手机端站点,站点地址为:https://m.mtime.cn/#.切换到登录页面,再分别输入账号和错误的密码, ...
- 列拖拽顺序调整-sortable.js使用
最近在做一个单表统计功能,涉及到一个查询列配置,但是查询出来的列顺序,可以进行配置,通过写列的排序当然阔以,但是方法就不美丽了.所以,在网上搜了一下拖拽的组件,最终定位Sortable.js,简单易用 ...
- POJ2376贪心
题意:数轴上有 n (1<=n<=25000)个闭区间 [ai, bi],选择尽量少的区间覆盖一条指定线段 [1,t](1<=t<=1,000,000).覆盖整点,即[1,2] ...
- Java数组的定义与使用
一.数组概念 可以将多个同一数据类型的数据,存储到同一个容器中 1. 格式 数据类型[] 数组名=new 数据类型[元素个数] "数据类型"表示该数组中可以存放哪一类型的数据 &q ...
- 快来!我从源码中学习到了一招Dubbo的骚操作!
荒腔走板 大家好,我是 why,欢迎来到我连续周更优质原创文章的第 55 篇. 老规矩,先来一个简短的荒腔走板,给冰冷的技术文注入一丝色彩. 魔幻的 2020 年的上半年过去了,很多人都在朋友圈和上半 ...
- python入门008
目录 一.for循环 作用:for循环是因为在循环取值(即遍历值)时for循环比while循环的使用更为简洁 1.for循环语法: 2.应用案例: 注意:break 与 continue也可以用于fo ...