Singly linked list algorithm implemented by Java

简介:

Linked list is a normal data structure.here I show how to implements it.

Step 1. Define a structure

1
2
3
4
5
6
7
8
9
public class ListNode
{
     public ListNode Next;
     public int Value;
     public ListNode( int NewValue)
     {
         Value = NewValue;
     }
}

Step 2. implements the functions

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
public class Clist
{
     private ListNode Head;
     private ListNode Tail;
     private ListNode Current;
     private int ListCountValue;
     
     public Clist()
     {
         ListCountValue = 0 ;
         Head = null ;
         Tail = null ;
     }
     
     public void Append( int DataValue)
     {
         ListNode NewNode = new ListNode(DataValue);
         if (ListCountValue == 0 )
         {
             Head = NewNode;
             Tail = NewNode;
         }
         else
         {
             Tail.Next = NewNode;
             Tail = NewNode;
         }
         Current = NewNode;
         ListCountValue += 1 ;
     }
     
     public void Insert( int DataValue)
     {
         ListNode NewNode = new ListNode(DataValue);
         if (ListCountValue == 0 )
         {
             Append(DataValue);
             return ;
         }
         if (Current == Tail)
         {
             Tail.Next = NewNode;
             Tail = NewNode;
             Current = Tail;
             ListCountValue += 1 ;
         }
         if ((Current != Head) && (Current != Tail))
         {
             NewNode.Next = Current.Next;
             Current.Next = NewNode;
             Current = NewNode;
             ListCountValue += 1 ;
         }
     }
     
     public void Delete()
     {
         if (ListCountValue != 0 )
         {
             if (Current == Head)
             {
                 Head = Current.Next;
                 Current = Head;
                 ListCountValue -= 1 ;
                 return ;
             }
             else
             {
                 Current = Current.Next;
                 ListCountValue -= 1 ;
             }
         }
     }
     
     public void printAllListNode()
     {
         Current = Head;
         for ( int i = 0 ; i < ListCountValue; i++)
         {
             System.out.println(Current.Value);
             Current = Current.Next;
         }
     }
}

Step 3. Test class for testing

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class Test
{
 
     public static void main(String[] args)
     {
         Clist clist = new Clist();
         clist.Append( 12 );
         clist.Append( 22 );
         clist.Insert( 66 );
         clist.Insert( 33 );
         clist.Delete();
         clist.printAllListNode();
     }
 
}

 

we will see:

1
2
3
4
12
22
66
33
相关实践学习
基于Hologres轻松玩转一站式实时仓库
本场景介绍如何利用阿里云MaxCompute、实时计算Flink和交互式分析服务Hologres开发离线、实时数据融合分析的数据大屏应用。
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
|
1月前
|
存储 Java
Java ArrayList 与 LinkedList 的灵活选择
Java ArrayList 类是一个可变大小的数组,位于 java.util 包中。
59 6
|
1月前
|
存储 安全 Java
ArrayList vs. LinkedList: Java集合框架的比较与应用
ArrayList vs. LinkedList: Java集合框架的比较与应用
|
1月前
|
存储 安全 Java
java集合框架及其特点(List、Set、Queue、Map)
java集合框架及其特点(List、Set、Queue、Map)
|
26天前
|
Java
Java使用List去重的四中方式
Java使用List去重的四中方式
19 6
|
1月前
|
Java
JAVA——List中剔除空元素(null)的三种方法汇总
JAVA——List中剔除空元素(null)的三种方法汇总
|
1月前
|
安全 Java API
Java并发 - J.U.C并发容器类 list、set、queue
Queue API 阻塞是通过 condition 来实现的,可参考 Java 并发 - Lock 接口 ArrayBlockingQueue 阻塞 LinkedBlockingQueue 阻塞 ArrayQueue 非阻塞 LinkedQueue 非阻塞
|
1月前
|
存储 安全 Java
【Java】集合(一)单列集合List
【Java】集合(一)单列集合List
22 0
|
1月前
|
Java API
java 对象list 使用stream进行过滤
在Java中,你可以使用Stream API对对象列表进行过滤。假设你有一个`List<MyObject>`,并且你想根据某些条件过滤出特定的对象。以下是一个示例: ```java import java.util.List; import java.util.stream.Collectors; public class Main { public static void main(String[] args) { List<MyObject> myObjects = ... // 初始化你的对象列表 List<MyObject> filter
|
1月前
|
算法 安全 Java
java将list中的某个元素移动位置
【2月更文挑战第12天】
|
1月前
|
存储 Java 容器
Java LinkedList类详解
Java LinkedList类详解