鏈隊列java實現,JAVA的隊列

本文目錄一覽:

怎麼編寫一個簡單的java隊列?

import java.util.*;

public class MyQueueT {

private LinkedListT list = new LinkedListT();

public void addLast(T v) {

list.addLast(v); //隊尾插入

}

public T getFirst() {

return list.getFirst(); //取得隊受元素

}

public void remove() {

list.removeFirst(); //移除隊首元素

}

//類似功能自己擴展下

public static void main(String[] args) {

MyQueueString mq = new MyQueueString();

mq.addLast(“hello world”);

mq.addLast(“hello world2”);

System.out.println(mq.getFirst());

mq.remove();

System.out.println(mq.getFirst());

}

}

JAVA里鏈隊怎麼移動指針

循環條件或者判斷語句。

為了和隊列的定義保持一致,所以要指明尾指針,鏈式隊列只是隊列的一種實現方式,還要把握住隊列的本質,至於尾指針指向是尾結點還是尾結點的下一個結點,這個只是實現的一點區別,沒有強制的要求。要根據自己的具體實現選擇,不同的應用這兩種會有些微小的區別,比如循環條件,判空等。

判斷依據是根據棧和堆解決,棧是後進先出,用鏈表的話在頭部操作即可,沒必要再加個尾指針,隊列是先進先出,頭尾都要有指針記憶位置,但是循環鏈表的話,尾節點的下一個便是頭結點,所以只要有個尾指針即可,頭指針省略不用。

java中的隊列用什麼實現

隊列的實現單純的是數據結構的問題,既可以用鏈表結構實現隊列,也可以用數組實現。這和語言不是緊密關係,java可以這樣實現,C、C++ 也可以。

求用Java的LinkedList類創建一個鏈隊列(LinkedQueue)類

LinkedQueue類代碼:

import java.util.LinkedList;

public class LinkedQueue {

private LinkedList list;

private LinkedQueue() {

}

public LinkedQueue(LinkedList list) {

this.list = list;

}

//入隊

public void add(Object obj) {

this.list.add(obj);

}

//獲取隊關元素

public Object get() {

return this.list.getFirst();

}

//出隊

public void next() {

this.list.removeFirst();

}

//判定為空

public boolean isEmpty() {

return this.list.isEmpty();

}

//獲取當前列隊長度

public int size() {

return this.list.size();

}

}

測試類代碼:

import java.util.LinkedList;

public class Test {

public static void main(String[] args) {

LinkedList list = new LinkedList();

list.add(“no1”);

list.add(“2”);

list.add(“215”);

//獲取初始linkedqueue;

LinkedQueue lq = new LinkedQueue(list);

System.out.println(“獲取隊頭元素 : ” + lq.get());

lq.add(“add”);

System.out.println(“入隊後隊列長度:: ” + lq.size());

lq.next();

System.out.println(“出隊隊列長度 : ” + lq.size());

System.out.println(“出隊後隊頭元素 : ” + lq.get());

System.out.println(“判定為空 : ” + lq.isEmpty());

}

}

java:編寫數據訪問接口,再分別以堆棧和隊列的形式實現

鏈隊列的定義:

隊列的鏈式存儲結構簡稱為鏈隊列。它是限制僅在表頭刪除和表尾插入的單鏈表。

鏈隊列的數據存儲形式:

鏈隊列基本運算的實現:

[java] view plain copy

package study_02.datastructure.queue;

/**

* 鏈隊列

* @author WWX

*/

public class LinkQueueT {

//鏈的數據結構

private class Node{

public T data;

public Node next;

//無參構造函數

public Node(){}

public Node(T data,Node next){

this.data=data;

this.next=next;

}

}

//隊列頭指針

private Node front;

//隊列尾指針

private Node rear;

//隊列長度

private int size=0;

public LinkQueue(){

Node n=new Node(null,null);

n.next=null;

front=rear=n;

}

/**

* 隊列入隊算法

* @param data

* @author WWX

*/

public void enqueue(T data){

//創建一個節點

Node s=new Node(data,null);

//將隊尾指針指向新加入的節點,將s節點插入隊尾

rear.next=s;

rear=s;

size++;

}

/**

* 隊列出隊算法

* @return

* @author WWX

*/

public T dequeue(){

if(rear==front){

try {

throw new Exception(“堆棧為空”);

} catch (Exception e) {

e.printStackTrace();

}

return null;

}else{

//暫存隊頭元素

Node p=front.next;

T x=p.data;

//將隊頭元素所在節點摘鏈

front.next=p.next;

//判斷出隊列長度是否為1

if(p.next==null)

rear=front;

//刪除節點

p=null;

size–;

return x;

}

}

/**

* 隊列長隊

* @return

* @author WWX

*/

public int size(){

return size;

}

/**

* 判斷隊列是否為空

* @return

* @author WWX

*/

public boolean isEmpty(){

return size==0;

}

public String toString() {

if(isEmpty()){

return “[]”;

}else{

StringBuilder sb = new StringBuilder(“[“);

for(Node current=front.next;current!=null;current=current.next){

sb.append(current.data.toString() + “, “);

}

int len = sb.length();

return sb.delete(len – 2, len).append(“]”).toString();

}

}

//測試

public static void main(String[] args) {

LinkQueueInteger queue=new LinkQueueInteger();

queue.enqueue(1);

queue.enqueue(2);

queue.enqueue(3);

queue.enqueue(4);

queue.enqueue(5);

queue.enqueue(6);

System.out.println(queue);

System.out.println(“出隊:”+queue.dequeue());

System.out.println(“隊列長度=”+queue.size());

System.out.println(queue);

System.out.println(“出隊:”+queue.dequeue());

System.out.println(“隊列長度=”+queue.size());

System.out.println(queue);

System.out.println(“出隊:”+queue.dequeue());

System.out.println(“隊列長度=”+queue.size());

System.out.println(queue);

}

}

輸出結果:

[1, 2, 3, 4, 5, 6]

出隊:1

隊列長度=5

[2, 3, 4, 5, 6]

出隊:2

隊列長度=4

[3, 4, 5, 6]

出隊:3

隊列長度=3

[4, 5, 6]

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/191009.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-30 09:07
下一篇 2024-11-30 09:08

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發佈。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論