[置顶] 小伙伴们来自己实现LinkedList
继前面实现ArrayList后,今天和小伙伴一起实现LinkedList,LinkedList实现我们采用双向链表来实现,在每次查找时候,如果该查找元素位于该链表的前半段,则从开始检索,如果位于链表的后半段,则从尾部开始检索。以下先贴出代码:
package com.david.duan;
import java.util.Iterator;
public class MyLinkedList implements Iterable<Student>{
//表示该链表的长度
private int theSize;
//每次链表被修改就增加此值
private int modCount;
//链表的头元素
private Node<Student> beginMarker;
//链表的尾元素
private Node<Student> endMarker;
//使用内部类来实现链表的每一个节点,每个节点有一个指向下一个元素的next,指向上一个元素的prev,以及自身的data
private static class Node<Student> {
public Node(Student data, Node<Student> prev, Node<Student> next) {
this.data = data;
this.prev = prev;
this.next = next;
}
public Student data;
public Node<Student> prev;
public Node<Student> next;
}
//链表的构造方法
public MyLinkedList () {
clear();
}
//清除链表,即使得链表的头元素指向链表的尾元素
public void clear () {
beginMarker = new Node<Student>(null, null, null);
endMarker = new Node<Student>(null, beginMarker, null);
beginMarker.next = endMarker;
}
//返回链表的长度
public int size() {
return theSize;
}
//判断链表是否为空
public boolean isEmplty() {
return size() == 0;
}
//向链表中添加元素
public boolean add(Student x) {
add(size(), x);
return true;
}
public void add(int idx, Student x) {
addBefore(getNode(idx), x);
}
//获取该节点的data
public Student get(int idx) {
return getNode(idx).data;
}
//设置该节点的值
public Student set(int idx, Student newData) {
Node<Student> oldNode = getNode(idx);
Student oldData = oldNode.data;
oldNode.data = newData;
return oldData;
}
//删除该节点,并返回该节点的值
public Student remove(int idx) {
return remove(getNode(idx));
}
private Student remove(Node<Student> p) {
p.prev.next = p.next;
p.next.prev = p.prev;
theSize--;
modCount++;
return p.data;
}
//执行添加
private void addBefore (Node<Student> p, Student x) {
Node<Student> newNode = new Node<Student>(x, p.prev, p);
newNode.prev.next = newNode;
p.prev = newNode;
modCount++;
}
//查找节点
private Node<Student> getNode(int idx) {
Node<Student> p;
if(idx <0 || idx > size()) {
throw new IndexOutOfBoundsException();
}
if(idx < size()/2) {
p = beginMarker.next;
for (int i = 0;i < idx;i++) {
p = p.next;
}
}else {
p = endMarker;
for (int i = size();i>idx;i--) {
p = p.prev;
}
}
return p;
}
//此处类似于前面的ArrayList,用以保存并返回当前元素
@Override
public Iterator<Student> iterator() {
return new LinkedListIterator();
}
private class LinkedListIterator implements java.util.Iterator<Student> {
private Node<Student> current = beginMarker.next;
private int expectedModCount = modCount;
private boolean okToRemove = false;
@Override
public boolean hasNext() {
return current != endMarker;
}
@Override
public Student next() {
if (modCount != expectedModCount ) {
throw new java.util.ConcurrentModificationException();
}
if(!hasNext()) {
throw new java.util.NoSuchElementException();
}
Student nextData = current.data;
current = current.next;
okToRemove = true;
return nextData;
}
@Override
public void remove() {
if (modCount != expectedModCount ) {
throw new java.util.ConcurrentModificationException();
}
if(!hasNext()) {
throw new java.util.NoSuchElementException();
}
MyLinkedList.this.remove(current.prev);
okToRemove = false;
expectedModCount++;
}
}
}
此处讲解不太详细的地方,欢迎大家留言探讨。
[置顶] 小伙伴们来自己实现LinkedList的更多相关文章
- [知了堂学习笔记]_css3特效第二篇--行走的线条&&置顶导航栏
一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...
- MySQL 上移/下移/置顶
在编写网站系统时,难免会用到上移.下移.置顶的功能,今天小编就介绍一下我的思路. 首先,需要一张数据表: CREATE TABLE `a` ( `id` ) NOT NULL AUTO_INCREME ...
- css3特效第二篇--行走的线条&&置顶导航栏
一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...
- 在UWP中页面滑动导航栏置顶
最近在研究掌上英雄联盟,主要是用来给自己看新闻,顺便copy个界面改一下段位装装逼,可是在我copy的时候发现这个东西 当你滑动到一定距离的时候导航栏会置顶不动,这个特性在微博和淘宝都有,我看了@ms ...
- WinFrom窗体始终置顶
调用WindowsAPI使窗体始终保持置顶效果,不被其他窗体遮盖: [DllImport("user32.dll", CharSet = CharSet.Auto)] privat ...
- winform窗体置顶
winform窗体置顶 金刚 winform 置顶 今天做了一个winform小工具.需要设置置顶功能. 网上找了下,发现百度真的很垃圾... 还是必应靠谱些. 找到一个可以链接. https://s ...
- 自定义置顶TOP按钮
简述一下,分为三个步骤: 1. 添加Html代码 2. 调整Css样式 3. 添加Jquery代码 具体代码如下: <style type="text/css"> #G ...
- ahk之路:利用ahk在window7下实现窗口置顶
操作系统:win7 64位 ahk版本:autohotkey_L1.1.24.03 今天安装了AutoHotkey_1.1.24.03.SciTE.PuloversMacroCreator,重新开始我 ...
- Qt中让Qwidget置顶的方法
一般来是说窗体置顶和取消只要 setWindowFlags(Qt::WindowStaysOnTopHint); setWindowFlags(Qt::Widget); 要 ...
随机推荐
- VMware Workstation下VMnet1等虚拟网卡与主机网卡之间的关系
VMware Workstation下VMnet1等虚拟网卡与主机网卡之间的关系 本文出自 "王春海的博客" http://wangchunhai.blog.51cto.com/2 ...
- iOS 7 - Auto Layout on iOS Versions prior to 6.0
链接地址:http://stackoverflow.com/questions/18735847/ios-7-auto-layout-on-ios-versions-prior-to-6-0 Stac ...
- VC6.0 导入资源崩溃
等我以后挣钱了一定买正版! 最近学习Win32编程,为了锻炼自己,在网上下载了一个VC6.0作为开发工具,应该是兼容性的问题吧,VC6 经常闹毛病. 今天导入资源的时候VC6出现崩溃的现象. 马上寻求 ...
- 使用Spring标签库
A.Spring标签库 Web项目若使用Spring Web MVC并使用JSP作为表现的话.从Spring2.0版本开始提供一套标签库可供使用. 使用标签库无非是易于开发,维护之类云云.这里就不阐述 ...
- 海量数据存储之Key-Value存储简介
Key-value存储简介 具备高可靠性及可扩展性的海量数据存储对互联网公司来说是一个巨大的挑战,传统的数据库往往很难满足该需求,并且很多时候对于特定的系统绝大部分的检索都是基于主键的的查询,在这种情 ...
- 基于visual Studio2013解决C语言竞赛题之0608水仙花函数
题目 解决代码及点评 /* 功能:写一函数判断某数是否"水仙花数",所谓"水仙花数"是指一个三位数, 其各位数字立方和等于该数本身. */ #includ ...
- IOS学习之segmented control
转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/27086877 作者:小马 什么是segmented control? 先上几张图: ...
- 搭建python集成开发环境.
需要搭建的内容一共有三项, python ,wxpython 以及spe. 其中spe 是python 的可视化集成开发环境(ide) , 其需要python GUI图形库wxpython的支 ...
- Java引用详解
区分几个概念 ,类 .对象 .对象的引用 A a1 = new A(); A a2 = a1; a1-------------------->对象内存<---------------- ...
- linux环境: shell初始化文件, for TCSH, CSH
TCSHELL, CSHELL 配置文件 全局配置文件 /etc/csh.cshrc个人配置文件 ~/.cshrc或~/.tcshrc 参考: 1.配置你的csh/tcsh, https://wik ...