LinkedList类是双向列表,列表中的每个节点都包含了对前一个和后一个元素的引用.
LinkedList的构造函数如下
1. public LinkedList(): ——生成空的链表
2. public LinkedList(Collection col): 复制构造函数
1、获取链表的第一个和最后一个元素
2、获取链表元素
3、从链表生成子表
4、添加元素:添加单个元素
如果不指定索引的话,元素将被添加到链表的最后.
public boolean add(Object element)
public boolean add(int index, Object element)
也可以把链表当初栈或者队列来处理:
public boolean addFirst(Object element)
public boolean addLast(Object element)
addLast()方法和不带索引的add()方法实现的效果一样.
5、删除元素
6、使用链表实现栈效果
7、使用链表来实现队列效果
lList.clear();
10、删除列表的首位元素
11、根据范围删除列表元素
12、删除链表的特定元素
13、将LinkedList转换为数组,数组长度为0
14、将LinkedList转换为数组,数组长度为链表长度
15、将LinkedList转换成ArrayList
16、实现栈
17、实现队列
18 、同步方法
19、查找元素位置
20、替换元素
21、链表添加对象
22、确认链表是否存在特定元素
23、根据链表元素生成对象数组
24、链表多线程
25、优先级链表(来自JBOSS)
26、生成list的帮助类(来自google)
LinkedList的构造函数如下
1. public LinkedList(): ——生成空的链表
2. public LinkedList(Collection col): 复制构造函数
1、获取链表的第一个和最后一个元素
- import java.util.LinkedList;
- public class LinkedListTest{
- public static void main(String[] args) {
- LinkedList<String> lList = new LinkedList<String>();
- lList.add("1");
- lList.add("2");
- lList.add("3");
- lList.add("4");
- lList.add("5");
- System.out.println("链表的第一个元素是 : " + lList.getFirst());
- System.out.println("链表最后一个元素是 : " + lList.getLast());
- }
- }
2、获取链表元素
- for (String str: lList) {
- System.out.println(str);
- }
- List subl = lList.subList(1, 4);
- System.out.println(subl);
- lst.remove(2);
- System.out.println(lst);
- System.out.println(lList);
如果不指定索引的话,元素将被添加到链表的最后.
public boolean add(Object element)
public boolean add(int index, Object element)
也可以把链表当初栈或者队列来处理:
public boolean addFirst(Object element)
public boolean addLast(Object element)
addLast()方法和不带索引的add()方法实现的效果一样.
- import java.util.LinkedList;
- public class LinkedListTest{
- public static void main(String[] a) {
- LinkedList list = new LinkedList();
- list.add("A");
- list.add("B");
- list.add("C");
- list.add("D");
- list.addFirst("X");
- list.addLast("Z");
- System.out.println(list);
- }
- }
- public Object removeFirst()
- public Object removeLast()
- import java.util.LinkedList;
- public class MainClass {
- public static void main(String[] a) {
- LinkedList list = new LinkedList();
- list.add("A");
- list.add("B");
- list.add("C");
- list.add("D");
- list.removeFirst();
- list.removeLast();
- System.out.println(list);
- }
- }
- import java.util.LinkedList;
- public class MainClass {
- public static void main(String[] args) {
- StackL stack = new StackL();
- for (int i = 0; i < 10; i++)
- stack.push(i);
- System.out.println(stack.top());
- System.out.println(stack.top());
- System.out.println(stack.pop());
- System.out.println(stack.pop());
- System.out.println(stack.pop());
- }
- }
- class StackL {
- private LinkedList list = new LinkedList();
- public void push(Object v) {
- list.addFirst(v);
- }
- public Object top() {
- return list.getFirst();
- }
- public Object pop() {
- return list.removeFirst();
- }
- }
- import java.util.LinkedList;
- public class MainClass {
- public static void main(String[] args) {
- Queue queue = new Queue();
- for (int i = 0; i < 10; i++)
- queue.put(Integer.toString(i));
- while (!queue.isEmpty())
- System.out.println(queue.get());
- }
- }
- class Queue {
- private LinkedList list = new LinkedList();
- public void put(Object v) {
- list.addFirst(v);
- }
- public Object get() {
- return list.removeLast();
- }
- public boolean isEmpty() {
- return list.isEmpty();
- }
- }
8、将LinkedList转换成ArrayList
- ArrayList<String> arrayList = new ArrayList<String>(linkedList);
- for (String s : arrayList) {
- System.out.println("s = " + s);
- }
9、删掉所有元素:清空LinkedList
lList.clear();
10、删除列表的首位元素
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] args) {
- LinkedList<String> lList = new LinkedList<String>();
- lList.add("1");
- lList.add("2");
- lList.add("3");
- lList.add("4");
- lList.add("5");
- System.out.println(lList);
- //元素在删除的时候,仍然可以获取到元素
- Object object = lList.removeFirst();
- System.out.println(object + " has been removed");
- System.out.println(lList);
- object = lList.removeLast();
- System.out.println(object + " has been removed");
- System.out.println(lList);
- }
- }
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] args) {
- LinkedList<String> lList = new LinkedList<String>();
- lList.add("1");
- lList.add("2");
- lList.add("3");
- lList.add("4");
- lList.add("5");
- System.out.println(lList);
- lList.subList(2, 5).clear();
- System.out.println(lList);
- }
- }
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] args) {
- LinkedList<String> lList = new LinkedList<String>();
- lList.add("1");
- lList.add("2");
- lList.add("3");
- lList.add("4");
- lList.add("5");
- System.out.println(lList);
- System.out.println(lList.remove("2"));//删除元素值=2的元素
- System.out.println(lList);
- Object obj = lList.remove(2); //删除第二个元素
- System.out.println(obj + " 已经从链表删除");
- System.out.println(lList);
- }
- }
- import java.util.LinkedList;
- import java.util.List;
- public class Main {
- public static void main(String[] args) {
- List<String> theList = new LinkedList<String>();
- theList.add("A");
- theList.add("B");
- theList.add("C");
- theList.add("D");
- String[] my = theList.toArray(new String[0]);
- for (int i = 0; i < my.length; i++) {
- System.out.println(my[i]);
- }
- }
- }
- import java.util.LinkedList;
- import java.util.List;
- public class Main {
- public static void main(String[] args) {
- List<String> theList = new LinkedList<String>();
- theList.add("A");
- theList.add("B");
- theList.add("C");
- theList.add("D");
- String[] my = theList.toArray(new String[theList.size()]);
- for (int i = 0; i < my.length; i++) {
- System.out.println(my[i]);
- }
- }
- }
- import java.util.ArrayList;
- import java.util.LinkedList;
- import java.util.List;
- public class Main {
- public static void main(String[] args) {
- LinkedList<String> myQueue = new LinkedList<String>();
- myQueue.add("A");
- myQueue.add("B");
- myQueue.add("C");
- myQueue.add("D");
- List<String> myList = new ArrayList<String>(myQueue);
- for (Object theFruit : myList)
- System.out.println(theFruit);
- }
- }
- import java.util.Collections;
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] argv) throws Exception {
- LinkedList stack = new LinkedList();
- Object object = "";
- stack.addFirst(object);
- Object o = stack.getFirst();
- stack = (LinkedList) Collections.synchronizedList(stack);
- }
- }
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] argv) throws Exception {
- LinkedList queue = new LinkedList();
- Object object = "";
- // Add to end of queue
- queue.add(object);
- // Get head of queue
- Object o = queue.removeFirst();
- }
- }
- import java.util.Collections;
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] argv) throws Exception {
- LinkedList queue = new LinkedList();
- Object object = "";
- queue.add(object);
- Object o = queue.removeFirst();
- queue = (LinkedList) Collections.synchronizedList(queue);
- }
- }
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] args) {
- LinkedList<String> lList = new LinkedList<String>();
- lList.add("1");
- lList.add("2");
- lList.add("3");
- lList.add("4");
- lList.add("5");
- lList.add("2");
- System.out.println(lList.indexOf("2"));
- System.out.println(lList.lastIndexOf("2"));
- }
- }
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] args) {
- LinkedList<String> lList = new LinkedList<String>();
- lList.add("1");
- lList.add("2");
- lList.add("3");
- lList.add("4");
- lList.add("5");
- System.out.println(lList);
- lList.set(3, "Replaced");//使用set方法替换元素,方法的第一个参数是元素索引,后一个是替换值
- System.out.println(lList);
- }
- }
- import java.util.LinkedList;
- class Address {
- private String name;
- private String street;
- private String city;
- private String state;
- private String code;
- Address(String n, String s, String c, String st, String cd) {
- name = n;
- street = s;
- city = c;
- state = st;
- code = cd;
- }
- public String toString() {
- return name + " " + street + " " + city + " " + state + " " + code;
- }
- }
- class MailList {
- public static void main(String args[]) {
- LinkedList<Address> ml = new LinkedList<Address>();
- ml.add(new Address("A", "11 Ave", "U", "IL", "11111"));
- ml.add(new Address("R", "11 Lane", "M", "IL", "22222"));
- ml.add(new Address("T", "8 St", "C", "IL", "33333"));
- for (Address element : ml)
- System.out.println(element + "\n");
- }
- }
- import java.util.LinkedList;
- public class Main {
- public static void main(String[] args) {
- LinkedList<String> lList = new LinkedList<String>();
- lList.add("1");
- lList.add("2");
- lList.add("3");
- lList.add("4");
- lList.add("5");
- if (lList.contains("4")) {
- System.out.println("LinkedList contains 4");
- } else {
- System.out.println("LinkedList does not contain 4");
- }
- }
- }
- Object[] objArray = lList.toArray();
- for (Object obj: objArray) {
- System.out.println(obj);
- }
- import java.util.Collections;
- import java.util.LinkedList;
- import java.util.List;
- class PrepareProduction implements Runnable {
- private final List<String> queue;
- PrepareProduction(List<String> q) {
- queue = q;
- }
- public void run() {
- queue.add("1");
- queue.add("done");
- }
- }
- class DoProduction implements Runnable {
- private final List<String> queue;
- DoProduction(List<String> q) {
- queue = q;
- }
- public void run() {
- String value = queue.remove(0);
- while (!value.equals("*")) {
- System.out.println(value);
- value = queue.remove(0);
- }
- }
- }
- public class Main {
- public static void main(String[] args) throws Exception {
- List q = Collections.synchronizedList(new LinkedList<String>());
- Thread p1 = new Thread(new PrepareProduction(q));
- Thread c1 = new Thread(new DoProduction(q));
- p1.start();
- c1.start();
- p1.join();
- c1.join();
- }
- }
- import java.util.ArrayList;
- import java.util.LinkedList;
- import java.util.List;
- import java.util.ListIterator;
- import java.util.NoSuchElementException;
- public class BasicPriorityLinkedList {
- protected LinkedList[] linkedLists;
- protected int priorities;
- protected int size;
- public BasicPriorityLinkedList(int priorities) {
- this.priorities = priorities;
- initDeques();
- }
- public void addFirst(Object obj, int priority) {
- linkedLists[priority].addFirst(obj);
- size++;
- }
- public void addLast(Object obj, int priority) {
- linkedLists[priority].addLast(obj);
- size++;
- }
- public Object removeFirst() {
- Object obj = null;
- for (int i = priorities - 1; i >= 0; i--) {
- LinkedList ll = linkedLists[i];
- if (!ll.isEmpty()) {
- obj = ll.removeFirst();
- break;
- }
- }
- if (obj != null) {
- size--;
- }
- return obj;
- }
- public Object removeLast() {
- Object obj = null;
- for (int i = 0; i < priorities; i++) {
- LinkedList ll = linkedLists[i];
- if (!ll.isEmpty()) {
- obj = ll.removeLast();
- }
- if (obj != null) {
- break;
- }
- }
- if (obj != null) {
- size--;
- }
- return obj;
- }
- public Object peekFirst() {
- Object obj = null;
- for (int i = priorities - 1; i >= 0; i--) {
- LinkedList ll = linkedLists[i];
- if (!ll.isEmpty()) {
- obj = ll.getFirst();
- }
- if (obj != null) {
- break;
- }
- }
- return obj;
- }
- public List getAll() {
- List all = new ArrayList();
- for (int i = priorities - 1; i >= 0; i--) {
- LinkedList deque = linkedLists[i];
- all.addAll(deque);
- }
- return all;
- }
- public void clear() {
- initDeques();
- }
- public int size() {
- return size;
- }
- public boolean isEmpty() {
- return size == 0;
- }
- public ListIterator iterator() {
- return new PriorityLinkedListIterator(linkedLists);
- }
- protected void initDeques() {
- linkedLists = new LinkedList[priorities];
- for (int i = 0; i < priorities; i++) {
- linkedLists[i] = new LinkedList();
- }
- size = 0;
- }
- class PriorityLinkedListIterator implements ListIterator {
- private LinkedList[] lists;
- private int index;
- private ListIterator currentIter;
- PriorityLinkedListIterator(LinkedList[] lists) {
- this.lists = lists;
- index = lists.length - 1;
- currentIter = lists[index].listIterator();
- }
- public void add(Object arg0) {
- throw new UnsupportedOperationException();
- }
- public boolean hasNext() {
- if (currentIter.hasNext()) {
- return true;
- }
- while (index >= 0) {
- if (index == 0 || currentIter.hasNext()) {
- break;
- }
- index--;
- currentIter = lists[index].listIterator();
- }
- return currentIter.hasNext();
- }
- public boolean hasPrevious() {
- throw new UnsupportedOperationException();
- }
- public Object next() {
- if (!hasNext()) {
- throw new NoSuchElementException();
- }
- return currentIter.next();
- }
- public int nextIndex() {
- throw new UnsupportedOperationException();
- }
- public Object previous() {
- throw new UnsupportedOperationException();
- }
- public int previousIndex() {
- throw new UnsupportedOperationException();
- }
- public void remove() {
- currentIter.remove();
- size--;
- }
- public void set(Object obj) {
- throw new UnsupportedOperationException();
- }
- }
- }
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.LinkedList;
- import java.util.List;
- public class Lists {
- private Lists() { }
- public static <E> ArrayList<E> newArrayList() {
- return new ArrayList<E>();
- }
- public static <E> ArrayList<E> newArrayListWithCapacity(int initialCapacity) {
- return new ArrayList<E>(initialCapacity);
- }
- public static <E> ArrayList<E> newArrayList(E... elements) {
- ArrayList<E> set = newArrayList();
- Collections.addAll(set, elements);
- return set;
- }
- public static <E> ArrayList<E> newArrayList(Iterable<? extends E> elements) {
- ArrayList<E> list = newArrayList();
- for(E e : elements) {
- list.add(e);
- }
- return list;
- }
- public static <E> LinkedList<E> newLinkedList() {
- return new LinkedList<E>();
- }
- }
相关推荐
本文将详细讲解如何使用Java中的LinkedList类来模拟这两种数据结构,并实现其基本操作。 堆栈(Stack)是一种后进先出(LIFO, Last In First Out)的数据结构,它遵循“先进后出”的原则。常见的堆栈操作有压栈...
Collection 接口还提供了一个 iterator() 方法,该方法返回一个迭代子,使用该迭代子即可逐一访问 Collection 中每一个元素。 List 接口是 Collection 接口的子接口,List 是有序的 Collection,使用此接口能够精确...
LinkedList内部使用双向链表实现,因此它的遍历速度比ArrayList快,但随机访问性能较差。本实例将探讨如何利用LinkedList以及比较器Comparator实现一个自定义排序的人事信息系统。 首先,我们需要创建一个表示人事...
了解了 LinkedList 的工作原理和使用方法后,可以根据实际需求选择适合的数据结构。在需要高效插入、删除且不需要快速随机访问元素的场景下,LinkedList 是一个理想的选择。然而,如果需要快速访问或遍历元素,数组...
LinkedList不仅可以作为列表使用,还可以被巧妙地利用来构建栈(Stack)和队列(Queue)这两种基本数据结构。在本篇内容中,我们将探讨如何通过LinkedList实现栈和队列,以及它们在实际编程中的应用。 首先,栈是一...
- LinkedList的基本操作:add()用于在链表末尾添加元素,addFirst()和addLast()分别用于在链表首尾添加元素,remove()删除指定元素,get()获取指定索引的元素,size()返回元素数量,isEmpty()检查链表是否为空。...
总的来说,理解ArrayList和LinkedList的基本特性和应用场景,以及如何处理与之相关的安全性问题,是Java程序员必备的知识。通过深入学习和实践,可以更好地利用这些数据结构提升程序效率和质量。
LinkedList是计算机科学中的一种基本数据结构,特别是在C++编程中,它被广泛用于处理动态集合。LinkedList的主要特点是每个元素(称为节点)包含数据以及指向下一个节点的指针,这种结构使得在列表中间添加或删除...
"Java集合框架LinkedList使用方法" Java集合框架中的LinkedList是一个双向链表,具有链表底层实现的特点,查询速度慢,增删速度快。LinkedList是Java集合框架中的一个重要组件,广泛应用于各种软件系统中。本文将...
在深入分析JDK 7.0中LinkedList集合的底层实现原理前,我们首先需要了解LinkedList的基本概念。LinkedList,即双向链表,是一种通过双向指针相互连接的数据结构,每个节点包含数据域以及指向前驱和后继节点的指针。...
虽然`LinkedList`提供了队列和栈的基本操作,但相比专门设计的数据结构(如`ArrayDeque`),在进行大量随机访问或在中间位置插入、删除操作时,`LinkedList`的性能较低,因为每次操作都需要遍历链表。在选择数据结构...
在Java中,我们可以利用LinkedList的addFirst()方法来模拟压栈操作,将新元素添加到链表头部,使用removeFirst()方法来模拟弹栈操作,删除并返回链表头部的元素。以下是一个简单的栈实现: ```java public class ...
下面通过几个示例来演示如何使用`LinkedList`进行基本操作: 1. **创建LinkedList**: ```java import java.util.LinkedList; public class RunoobTest { public static void main(String[] args) { ...
通过上述介绍,我们可以了解到`LinkedList`在Java中的基本使用方法,包括如何增加、删除和获取元素,以及如何使用`ListIterator`和`Iterator`来进行遍历。对于开发人员来说,了解这些基础知识是非常重要的,它可以...
本文将深入探讨LinkedList的实现原理、核心方法的代码实现,并对比ArrayList,理解其特性和使用场景。 首先,LinkedList底层采用链表数据结构,这种结构允许在任意位置插入和删除元素,而不需要移动其他元素。链表...
本文将深入探讨`LinkedList`类的特性、使用场景以及基本操作。 **1. 链表的类型** 链表分为两种主要类型: - **单向链表**:每个节点仅有一个指向前一个或后一个节点的链接。 - **双向链表**:每个节点包含两个链接...
LinkedList集合继承自AbstractSequentialList抽象类,实现了List接口,提供了基本的集合操作方法,如add、remove、get等。 LinkedList集合的特有方法 与其他集合实现不同,LinkedList集合提供了一些特殊的方法来...
这个LinkedList类提供了基本的操作,如`append`、`insertAt`、`remove`和`find`。`traverse`方法用于打印链表中的所有元素。在实际应用中,可能还需要扩展其他功能,如根据条件查找、反转链表、合并两个链表等。 ...
递归方法通常更加简洁,但在某些情况下可能不如迭代方法高效。 - **辅助节点**:在处理某些链表问题时,使用额外的“虚拟头结点”或“哑结点”可以帮助简化代码逻辑。 4. **链表问题分析**: - **问题分类**:...
- **添加元素**:LinkedList提供了`addFirst()`、`addLast()`、`add(index, element)`等方法来在链表的头部、尾部或指定位置插入元素。 - **删除元素**:`removeFirst()`、`removeLast()`和`remove(index)`用于...