2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
ArrayList इत्यस्मिन् कस्मिन् अपि स्थाने तत्त्वानि सम्मिलितुं वा विलोपयन्ते सति, भवद्भिः सम्पूर्णानि अनन्तरं तत्त्वानि अग्रे वा पश्चात् वा गन्तुं आवश्यकानि सन्ति तथा च कार्यक्षमता तुल्यकालिकरूपेण न्यूना भवति अतः ArrayList कस्मिन् अपि स्थाने सम्मिलितुं विलोपयितुं च उपयुक्ता नास्ति स्थितिः दृश्यम् । अतः: LinkedList, लिङ्क्ड् सूचीसंरचना, जावासङ्ग्रहेषु प्रवर्तते ।
२.१ लिङ्क्ड् सूचीयाः अवधारणा संरचना च
लिङ्क्ड् सूची भौतिकरूपेण अनिरन्तरं भण्डारणसंरचना भवति, तथा च लिङ्क्ड् सूचीयां सन्दर्भलिङ्क् क्रमेण दत्तांशतत्त्वानां तार्किकक्रमः प्राप्तः भवति
२.२ लिङ्क्ड् सूचीयाः कार्यान्वयनम्
1. शीर्षकं सम्मिलनविधिः addFirst() .
- public void addFirst(int data) {
- ListNode node = new ListNode(data);
- node.next = head;
- head = node;
- }
2. पुच्छं सम्मिलनविधिः addLast() .
- public void addList(int data) {
- ListNode node = new ListNode(data);
- if (head == null) {
- head = node;
- }
- ListNode cur = head;
- while (cur.next != null) {
- cur = cur.next;
- }
- cur.next = node;
- }
3.adIndex () 1.1.
- public void addIndex(int index, int data) {
- int len = size();
- // 不合法
- if (index < 0 || index > len) {
- System.out.println("index不合法");
- return;
- }
- // 空链表
- if (index == 0) {
- addFirst(data);
- return;
- }
- // 尾部插入
- if (index == len) {
- addLast(data);
- return;
- }
-
- //中间位置插入
- ListNode cur = head;
- while (index - 1 != 0) {
- cur = cur.next;
- index--;
- }
- ListNode node = new ListNode(data);
- node.next = cur.next;
- cur.next = node;
- }
४.युक्तम्() २.
- public boolean contains(int key) {
- ListNode cur = head;
- while (cur != null) {
- if (cur.val == key) {
- return true;
- }
- cur = cur.next;
- }
- return false;
- }
5.हटयतु() .
- public void remove(int key) {
- if (head == null) {
- return;
- }
- if (head.val == key) {
- head = head.next;
- }
-
- ListNode cur = findNodeOfKey(key);
- if (cur == null) {
- return;
- }
- ListNode del = cur.next;
- cur.next = del.next;
- }
-
- private ListNode findNodeOfKey(int key) {
- ListNode cur = head;
- while (cur.next != null) {
- if (cur.next.val == key) {
- return cur;
- }
- cur = cur.next;
- }
- return null;
- }
6.removeAllKey () 1.1.
- public void removeAllKey(int key) {
- ListNode cur = head.next;
- ListNode prev = head;
- while (cur != null) {
- if (cur.val == key) {
- prev.next = cur.next;
- } else {
- prev = cur;
- }
- cur = cur.next;
- }
- if (head.val == key) {
- head = head.next;
- }
- }
७.स्पष्टम्() २.
- public void clear() {
- ListNode cur = head;
- while (cur != null) {
- ListNode curNext = cur.next;
- cur.next = null;
- cur = curNext;
- }
- head = null;
- }
८.आकारः() २.
- public int size() {
- int count = 0;
- ListNode cur = head;
- while (cur != null) {
- count++;
- cur = cur.next;
- }
- return count;
- }
9.प्रदर्शनम्() .
- public void display() {
- ListNode cur = head;
- while (cur != null) {
- System.out.print(cur.val + " ");
- cur = cur.next;
- }
- }
- / 2、无头双向链表实现
- public class MyLinkedList {
- //头插法
- public void addFirst(int data){ }
- //尾插法
- public void addLast(int data){}
- //任意位置插入,第一个数据节点为0号下标
- public void addIndex(int index,int data){}
- //查找是否包含关键字key是否在单链表当中
- public boolean contains(int key){}
- //删除第一次出现关键字为key的节点
- public void remove(int key){}
- //删除所有值为key的节点
- public void removeAllKey(int key){}
- //得到单链表的长度
- public int size(){}
- public void display(){}
- public void clear(){}
- }
- package DounlyLinkedList;
-
- import java.util.LinkedList;
- import java.util.List;
-
- public class MyDoublyLinkedList implements IList {
-
- static class ListNode {
- public int val;
- public ListNode next;
- public ListNode prev;
-
- public ListNode(int val) {
- this.val = val;
- }
- }
-
- public ListNode head;
- public ListNode last;
-
-
- @Override
- public void addFist(int data) {
- ListNode node = new ListNode(data);
- if (head == null) {
- head = node;
- last = node;
- } else
- node.next = head;
- head.prev = node;
- head = node;
- }
-
- @Override
- public void addLast(int data) {
- ListNode node = new ListNode(data);
- if (head == null) {
- head = node;
- last = node;
- }
- last.next = node;
- node.prev = last;
- last = node;
- }
-
- @Override
- public void addIndex(int index, int data) {
- int len = size();
- if (index < 0 || index > len) {
- System.out.println("index 不合法!");
- }
-
- if (index == 0) {
- addFist(data);
- return;
- }
-
- if (index == len) {
- addLast(data);
- return;
- }
- ListNode cur = findIndex(index);
- ListNode node = new ListNode(data);
- node.next = cur;
- cur.prev.next = node;
- node.prev = cur.prev;
- cur.prev = node;
- }
-
- private ListNode findIndex(int index) {
- ListNode cur = head;
- while (index != 0) {
- cur = cur.next;
- index--;
- }
- return cur;
- }
-
-
- @Override
- public boolean contains(int key) {
- ListNode cur = head;
- int count = 0;
- while (cur != null) {
- if (cur.val == key) {
- return true;
- }
- cur = cur.next;
- }
- return false;
- }
-
- @Override
- public void remove(int key) {
- ListNode cur = head;
- while (cur != null) {
- if (cur.val == key) {
- if (cur == head) {
- head = head.next;
- if (head != null) {
- head.prev = null;
- }
- head.prev = null;
- } else {
- cur.prev.next = cur.next;
- if (cur.next == null) {
- last = last.prev;
- } else {
- cur.next.next = cur.prev;
- }
- }
- return;
- }
- cur = cur.next;
-
- }
- }
-
- @Override
- public void removeAllKey(int key) {
- ListNode cur = head;
- while (cur != null) {
- if (cur.val == key) {
- if (cur == head) {
- head = head.next;
- if (head != null) {
- head.prev = null;
- }
- head.prev = null;
- } else {
- cur.prev.next = cur.next;
- if (cur.next == null) {
- last = last.prev;
- } else {
- cur.next.next = cur.prev;
- }
- }
- }
- cur = cur.next;
- }
- }
-
- @Override
- public int size() {
- ListNode cur = head;
- int count = 0;
- while (cur != null) {
- count++;
- cur = cur.next;
- }
- return count;
- }
-
- @Override
- public void clear() {
- ListNode cur = head;
- while (cur != null) {
- ListNode curNext = cur.next;
- cur.next = null;
- cur.prev = null;
- cur = curNext;
- }
- head = null;
- last = null;
- }
-
- @Override
- public void dispaly() {
- ListNode cur = head;
- while (cur != null) {
- System.out.print(cur.val + " ");
- cur = cur.next;
- }
- System.out.println();
- }
- }
-
-
-
-
-
- package DounlyLinkedList;
-
- public interface IList {
- void addFist(int data);
-
- void addLast(int data);
-
- void addIndex(int index, int data);
-
- boolean contains(int key);
-
- void remove(int key);
-
- void removeAllKey(int key);
-
- int size();
-
- void clear();
-
- void dispaly();
- }
४.१ लिङ्क्ड्लिस् इति किम्
【दृष्टान्तः 】 २.
1. LinkedList List interface इत्यस्य कार्यान्वयनम् करोति
2. LinkedList इत्यस्य अन्तर्निहितस्तरः द्विगुणलिङ्कितसूचीं उपयुज्यते
3. LinkedList RandomAccess अन्तरफलकं कार्यान्वितं न करोति, अतः LinkedList यादृच्छिकप्रवेशस्य समर्थनं न करोति ।
4. LinkedList इत्यस्मिन् कस्मिन् अपि स्थाने तत्त्वानि सम्मिलितुं विलोपनं च तुल्यकालिकरूपेण कुशलं भवति, तथा च समयजटिलता O(1) भवति ।
5. LinkedList कस्मिन् अपि स्थाने सम्मिलनपरिदृश्यानां कृते अधिकं उपयुक्तम् अस्ति
४.२ LinkedList इत्यस्य उपयोगः
1. LinkedList इत्यस्य निर्माणम्
प्रक्रिया | व्याख्याति |
लिङ्क्ड्लिस्ट्() . | नो-तर्कनिर्माणम् |
public LinkedList (संग्रह | अन्यसङ्ग्रहपात्रेभ्यः तत्त्वानां उपयोगेन List निर्मायताम् |
- import java.util.LinkedList;
- import java.util.List;
-
- public class Test {
- public static void main(String[] args) {
- List<Integer> list1 = new LinkedList<>();
- List<String> list2 = new java.util.ArrayList<>();
-
- list2.add("javaSE");
- list2.add("javaWeb");
- list2.add("javaEE");
-
- List<String> list3 = new LinkedList<>(list2);
-
- }
- }
-
-
2. LinkedList इत्यस्य अन्येषां सामान्यविधीनां परिचयः
प्रक्रिया | व्याख्याति |
बूलियन add(E e) 1.1. | पुच्छ प्लग ङ |
void add(int अनुक्रमणिका, ई तत्व) | अनुक्रमणिकास्थाने e सम्मिलितं कुर्वन्तु |
boolean addAll (संग्रह ग) 1.1. | अन्ते c इत्यस्मिन् तत्त्वानि निवेशयन्तु |
E remove(int index) २. | अनुक्रमणिकास्थानतत्त्वं विलोपयन्तु |
boolean remove(वस्तु ओ) २. | प्रथमं o सम्मुखीकृतं विलोपयन्तु |
E get(int index) ९. | उपलिपि अनुक्रमणिका स्थितितत्त्वं प्राप्नुवन्तु |
E set(int index, ई तत्व) 1.1. | उपलिपि अनुक्रमणिकास्थानतत्त्वं तत्त्वे सेट् कुर्वन्तु |
शून्य स्पष्ट() २. | स्पष्टः |
boolean contains(Object o) इति । | रेखीयसारणीयां o अस्ति वा इति निर्धारयतु |
int indexOf(वस्तु ओ) . | यत्र प्रथमः o स्थितः अस्ति तत्र अनुक्रमणिकां प्रत्यागच्छतु |
int lastIndexOf (वस्तु o) . | अन्तिमस्य o इत्यस्य उपलिपिं प्रत्यागच्छति |
सूची subList(int fromIndex, int toIndex) | सूचीयाः भागं अवरुद्धं कुर्वन्तु |
- public static void main(String[] args) {
- LinkedList<Integer> list = new LinkedList<>();
- list.add(1); // add(elem): 表示尾插
- list.add(2);
- list.add(3);
- list.add(4);
- list.add(5);
- list.add(6);
- list.add(7);
- System.out.println(list.size());
- System.out.println(list);
- // 在起始位置插入0
- list.add(0, 0); // add(index, elem): 在index位置插入元素elem
- System.out.println(list);
- list.remove(); // remove(): 删除第一个元素,内部调用的是removeFirst()
- list.removeFirst(); // removeFirst(): 删除第一个元素
- list.removeLast(); // removeLast(): 删除最后元素
- list.remove(1); // remove(index): 删除index位置的元素
- System.out.println(list);
- // contains(elem): 检测elem元素是否存在,如果存在返回true,否则返回false
- if(!list.contains(1)){
- list.add(0, 1);
- }
- list.add(1);
- System.out.println(list);
- System.out.println(list.indexOf(1)); // indexOf(elem): 从前往后找到第一个elem的位置
- System.out.println(list.lastIndexOf(1)); // lastIndexOf(elem): 从后往前找第一个1的位置
- int elem = list.get(0); // get(index): 获取指定位置元素
- list.set(0, 100); // set(index, elem): 将index位置的元素设置为elem
- System.out.println(list);
- // subList(from, to): 用list中[from, to)之间的元素构造一个新的LinkedList返回
- List<Integer> copy = list.subList(0, 3);
- System.out.println(list);
- System.out.println(copy);
- list.clear(); // 将list中元素清空
- System.out.println(list.size());
- }
3. LinkedList इत्यस्य भ्रमणम्
- public static void main(String[] args) {
- LinkedList<Integer> list = new LinkedList<>();
- list.add(1); // add(elem): 表示尾插
- list.add(2);
- list.add(3);
- list.add(4);
- list.add(5);
- list.add(6);
- list.add(7);
- System.out.println(list.size());
- // foreach遍历
- for (int e:list) {
- System.out.print(e + " ");
- }
- System.out.println();
- // 使用迭代器遍历---正向遍历
- ListIterator<Integer> it = list.listIterator();
- while(it.hasNext()){
- System.out.print(it.next()+ " ");
- }
- System.out.println();
- // 使用反向迭代器---反向遍历
- ListIterator<Integer> rit = list.listIterator(list.size());
- while (rit.hasPrevious()){
- System.out.print(rit.previous() +" ");
- }
- System.out.println();
- }
अंतरण | ArrayList इति | LinkedList इति |
भण्डारणस्थाने | भौतिकरूपेण निरन्तरता भवितुमर्हति | तार्किकरूपेण निरन्तरता, न तु भौतिकरूपेण निरन्तरता इति अनिवार्यम् |
यादृच्छिक अभिगम | समर्थन ओ(१) ९. | समर्थितः नास्ति: O(N) |
शिरः प्लग | तत्त्वान् चालयितुं आवश्यकता, न्यूनदक्षता O(N) | केवलं सन्दर्भस्य सूचकं परिवर्तयन्तु, समयजटिलता O(1) भवति । |
युज् | यदा स्थानं अपर्याप्तं भवति तदा विस्तारस्य आवश्यकता भवति | न क्षमतायाः अवधारणा |
अनुप्रयोग परिदृश्य | तत्त्वानां कुशलं भण्डारणं + नित्यं प्रवेशः | कस्मिन् अपि स्थाने बहुधा सम्मिलनम्, लोपः च |