数组链表实现List

数组链表

数组ArrayList

Code:

//可变数组 class ArrayList_{ //初始容器大小 private static int DEFAULT_SIZE = 10; //容器 Object[] objects = new Object[DEFAULT_SIZE]; //当前的大小 private int size = 0; //添加元素 public void add(Object o){ //如果容器满了的话,扩容原来容器的2倍 if (size == objects.length){ Object[] newObjects = Arrays.copyOf(this.objects, this.objects.length * 2); objects = newObjects; } objects[size] = o; size++; } public int size(){ return size; } }

Test:

public class TestIterator { public static void main(String[] args) { ArrayList_ arrayList = new ArrayList_(); for (int i = 0; i < 15; i++) { arrayList.add("s: "+ i); } System.out.println(arrayList.objects.length); for (int i = 0; i < arrayList.size(); i++) { System.out.println(arrayList.objects[i]); } } }

链表实现LinkedList

Code:

//链表 class LinkedList_{ //保存链表的头部节点 Node head = null; //保存链表的尾部节点 Node tail = null; //容器大小计数器 private int size = 0; //添加元素 public void add(Object o){ //把object 封装成Node节点 Node node = new Node(o); node.next = null; //判断头节点是否为空, if (head == null){ head = node; tail = node; } //将原来最后一个的节点next 指向新添加的节点 tail.next = node; //把尾部节点跟新成新增加的 tail = node; //容量加一 size++; } public int size(){ return size; } //元素类 class Node{ private Object object; private Node next; public Node(Object object) { this.object = object; } } }

__EOF__

本文作者Immortal-mode
本文链接https://www.cnblogs.com/immortal-mode/p/14396050.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   immortal_mode  阅读(84)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示