2019.10.19雙向鏈表

来源:https://www.cnblogs.com/lonelyleo/archive/2019/10/19/11706013.html
-Advertisement-
Play Games

import java.util.NoSuchElementException;public class LinkedListT<E> { private Node<E> first; private Node<E> last; long size = 0l; private void linkLa ...



import java.util.NoSuchElementException;

public class LinkedListT<E> {
private Node<E> first;

private Node<E> last;

long size = 0l;

private void linkLast(E e) {
Node<E> temp = last;
Node<E> newNode = new Node<E>(temp, e, null);
last = newNode;
if (temp == null) {
first = newNode;
} else {
temp.next = newNode;
}
size++;
}

public boolean add(E e) {
linkLast(e);
return true;
}

public boolean add(long index, E e) {
checkInsertIndex(index);
if (index > 0 && index < size) {
//從前到後的查法
/*long j = 0;
for (Node<E> i = first; i != null; i = i.next, j++) {
if (j == index) {
Node<E> newNode = new Node<>(i.prev, e, i);
i.prev.next = newNode;
i.prev = newNode;
}
}*/
//分前後查找法
Node<E> node = indexNode(isSize(index), index);
Node<E> newNode = new Node<>(node.prev, e, node);
node.prev.next = newNode;
node.prev = newNode;
size++;
} else if (index == 0) {
addFirst(e);
}
if (index == size) {
linkLast(e);
}
return true;
}

public void checkInsertIndex(long index) {
if (index > size || index < 0) {
throw new IndexOutOfBoundsException();
}
}

public Boolean addFirst(E e) {
if (size == 0) {
linkLast(e);
} else {
Node<E> newNode = new Node<>(null, e, first);
first.prev = newNode;
first = newNode;
size++;
}
return true;
}

public Boolean addLast(E e) {
linkLast(e);
return true;
}

public E getFirst() {
if (first == null) {
throw new NoSuchElementException();
}
return first.item;
}

public E getLast() {
if (last == null) {
throw new NoSuchElementException();
}
return last.item;
}

public long getSize() {
return size;
}

public E get(long index) {
E result = null;
checkInsertIndex(index);
long j = 0;
for (Node<E> i = first; i != null; i = i.next, j++) {
if (j == index) {
result = i.item;
}
}
return result;
}

public void removeAll() {
first = null;
last = null;
size = 0;
}

public E remove(long index) {
E e = null;
checkRemoveIndex(index);
if (index != 0 && index != size - 1){
Node<E> node = indexNode(isSize(index), index);
// Node<E> prev = node.prev;
node.prev.next = node.next;
node.next.prev = node.prev;
e = node.item;
node = null;
size--;
}else if(index == 0){
e = removeFirst();
}else {
e = removeLast();
}
return e;
}

private void checkRemoveIndex(long index){
if (index >= size || index < 0) {
throw new IndexOutOfBoundsException();
}
}

private Node<E> indexNode(boolean flag, long index) {
long j = 0;
Node<E> node = null;
if (flag) {
for (Node<E> i = first; i != null; i = i.next, j++) {
if (index == j) {
node = i;
}
}
} else {
j = size - 1;
for (Node<E> i = last; i != null; i = i.prev, j--) {
if (index == j){
node = i;
}
}
}
return node;
}

private boolean isSize(long index) {
if (size / 2 >= index) {
return true;
} else {
return false;
}
}

public E remove(Object obj) {
E e = null;
if (obj == null){
for ( Node<E> i = first;i != null;i = i.next){
if (i.item == obj){
e = unlink(i);
}
}
}else {
for ( Node<E> i = first;i != null;i = i.next){
if (i.item.equals(obj)){
e = unlink(i);
}
}
}
return e;
}

E unlink(Node<E> x) {
E element = x.item;
Node<E> next = x.next;
Node<E> prev = x.prev;

if (prev == null) {
first = next;
} else {
prev.next = next;
x.prev = null;
}

if (next == null) {
last = prev;
} else {
next.prev = prev;
x.next = null;
}

x.item = null;
size--;
return element;
}

public E removeFirst() {
if (size == 0) {
throw new IndexOutOfBoundsException();
}
Node<E> second = first.next;
E e = first.item;
first.next = null;
if (second == null) {
last = null;
} else {
second.prev = null;
}
first = second;
size--;
return e;
}

public E removeLast() {
if (size == 0) {
throw new IndexOutOfBoundsException();
}
Node<E> secondLast = last.prev;
E e = last.item;
last.prev = null;
if (secondLast == null) {
first = null;
} else {
secondLast.next = null;
}
last = secondLast;
size--;
return e;
}

private static class Node<E> {
E item;
Node<E> next;
Node<E> prev;

Node(Node<E> prev, E item, Node<E> next) {
this.item = item;
this.next = next;
this.prev = prev;
}
}

@Override
public String toString() {
StringBuffer str = new StringBuffer("");
for (Node<E> i = first; i != null; i = i.next) {
str.append(i.item);
if (i.next != null) {
str.append(",");
}
}
return "[" + str.toString() + "]";
}
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前兩天看到 某個程式猿寫了個爬蟲,然後公司200多人被端, 作為在入門python 的小白, 產生了興趣,於是乎學習了下,寫了一個小爬蟲,做一些入門的抓爬,爬點美女圖片吧 ! let's do it 看一眼美女,寫代碼的興緻就上來了 爬蟲是通過找到要爬的圖片的url 然後進行下載, 這個url怎麼找 ...
  • 前端頁面代碼 <!-- enctype 定義form要上傳文件類型--> <form action="" method="post" id="t" enctype="multipart/form-data"> <!-- multiple 作用是可以同時選中多個文件,多張圖片 accept 指定inp ...
  • 寫在最前 我寫過很多篇秋招總結,這篇文章應該是最後一篇總結,當然也是最完整,最詳細的一篇總結。秋招是我人生中一段寶貴的經歷,不僅是我研究生生涯交出的一份答卷,也是未來職業生涯的開端。僅以此文,獻給自己,以及各位在求職路上的,或者是已經經歷過校招的朋友們。不忘初心,方得始終。 前言 在下本是跨專業渣考 ...
  • 作為一個非科班小白,我在讀研期間基本是自學Java,從一開始幾乎零基礎,只有一點點數據結構和Java方面的基礎,到最終獲得網易游戲的Java實習offer,我大概用了半年左右的時間。本文將會講到我在這半年裡做對了哪些事情。 前言 研究生時期的方向選擇 對於即將讀研的同學來說,一般有兩件事很重要,一件 ...
  • 2019滴滴java面試總結 (包含面試題) 本人6年開發經驗、今年年初找工作,在互聯網寒冬下成功拿到阿裡巴巴、今日頭條、滴滴等公司offer,崗位是既有php也有Java後端開發,最終選擇去了滴滴。 面試了很多家公司,感覺大部分公司考察的點都差不多,所以將自己的心得記下來,希望能給正在找或者準備找 ...
  • 系統中的很多頁面有很多公共內容,例如菜單、頁腳等,這些公共內容可以提取放在一個稱為“模板片斷”的公共頁面裡面,其它頁面可以引用這個 “模板片斷”內容。 ...
  • 併發容器 一、ConcurrentHashMap 【1】引入ConcurrentHashMap的目的 ​ ConcurrentHashMap從JDK1.5開始隨java.util.concurrent包一起引入JDK中,主要為瞭解決HashMap線程不安全和Hashtable效率不高的問題。眾所周知 ...
  • 恢復內容開始 盯著電腦工作大半天了,有點疲勞,想想同樣苦逼盯著電腦的女朋友,就想逗逗她緩解一下疲勞。 於是一時手癢,開始了新一輪的騷操作,用Python基於itchat實現微信控制電腦打開攝像頭拍攝當前電腦的使用者並且將圖片發送到你微信上的功能。看到圖片後差點閃瞎我 24k 血輪眼。打碼上圖: 本操 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...