Singly linked list algorithm implemented by Java

本文涉及的产品
可视分析地图(DataV-Atlas),3 个项目,100M 存储空间
简介:

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
相关实践学习
DataV Board用户界面概览
本实验带领用户熟悉DataV Board这款可视化产品的用户界面
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
|
5月前
|
存储 Java 索引
【Java集合类面试二十四】、ArrayList和LinkedList有什么区别?
ArrayList基于动态数组实现,支持快速随机访问;LinkedList基于双向链表实现,插入和删除操作更高效,但占用更多内存。
|
7月前
|
安全 Java
java线程之List集合并发安全问题及解决方案
java线程之List集合并发安全问题及解决方案
1099 1
|
2月前
|
存储 Java 索引
Java中的数据结构:ArrayList和LinkedList的比较
【10月更文挑战第28天】在Java编程世界中,数据结构是构建复杂程序的基石。本文将深入探讨两种常用的数据结构:ArrayList和LinkedList,通过直观的比喻和实例分析,揭示它们各自的优势与局限,帮助你在面对不同的编程挑战时做出明智的选择。
|
3月前
|
安全 Java 程序员
Java集合之战:ArrayList vs LinkedList,谁才是你的最佳选择?
本文介绍了 Java 中常用的两个集合类 ArrayList 和 LinkedList,分析了它们的底层实现、特点及适用场景。ArrayList 基于数组,适合频繁查询;LinkedList 基于链表,适合频繁增删。文章还讨论了如何实现线程安全,推荐使用 CopyOnWriteArrayList 来提升性能。希望帮助读者选择合适的数据结构,写出更高效的代码。
147 3
|
3月前
|
存储 Java 索引
Java LinkedList详解
`LinkedList`是Java集合框架中的一个重要类,实现了`List`、`Deque`和`Cloneable`接口。它基于双向链表,支持动态扩展,允许重复元素。虽然通过索引访问元素的时间复杂度为O(n),但在插入和删除操作上表现优异,时间复杂度为O(1)。常用操作包括创建、添加、获取、删除和查找元素,以及使用迭代器遍历。适用于频繁插入和删除的场景,如队列和栈的实现。
117 6
|
5月前
|
存储 算法 Java
14 Java集合(集合框架+泛型+ArrayList类+LinkedList类+Vector类+HashSet类等)
14 Java集合(集合框架+泛型+ArrayList类+LinkedList类+Vector类+HashSet类等)
69 2
14 Java集合(集合框架+泛型+ArrayList类+LinkedList类+Vector类+HashSet类等)
|
5月前
|
存储 消息中间件 Java
何时在 Java 中使用 ArrayList 和 LinkedList
【8月更文挑战第23天】
50 2
|
5月前
|
存储 Java
|
5月前
|
存储 Java 索引
Java 中 ArrayList 和 LinkedList 之间的区别
【8月更文挑战第22天】
153 1
|
6月前
|
Java API Apache
怎么在在 Java 中对List进行分区
本文介绍了如何将列表拆分为给定大小的子列表。尽管标准Java集合API未直接支持此功能,但Guava和Apache Commons Collections提供了相关API。