Java定義隊(duì)列結(jié)構(gòu),并實(shí)現(xiàn)入隊(duì)、出隊(duì)操作完整示例
本文實(shí)例講述了Java定義隊(duì)列結(jié)構(gòu),并實(shí)現(xiàn)入隊(duì)、出隊(duì)操作。分享給大家供大家參考,具體如下:
package com.example.demo;
import java.util.ArrayList;
public class Queue {
ArrayList<Object> list = new ArrayList<>();
//入隊(duì)
public void in(Object o) {
list.add(o);
}
//出隊(duì)
public Object out() {
Object o = list.get(0);
list.remove(o);
return o;
}
//隊(duì)是否為空
public boolean isEmpty() {
return list.isEmpty();
}
//隊(duì)大小
public int size() {
return list.size();
}
//打印隊(duì)元素
@Override
public String toString() {
return String.valueOf(list);
}
}
class main {
public static void main(String[] args) {
//創(chuàng)建一個隊(duì)列
Queue queue = new Queue();
//入隊(duì)
for(int i=1;i<=10;i++){
queue.in(i);
}
//出隊(duì)
while(!queue.isEmpty()){
System.out.println("隊(duì):" + queue.toString() + "\t隊(duì)大小為:" + queue.size() + "\t出隊(duì)元素為:" + queue.out());
}
}
}
運(yùn)行結(jié)果:
隊(duì):[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 隊(duì)大小為:10 出隊(duì)元素為:1
隊(duì):[2, 3, 4, 5, 6, 7, 8, 9, 10] 隊(duì)大小為:9 出隊(duì)元素為:2
隊(duì):[3, 4, 5, 6, 7, 8, 9, 10] 隊(duì)大小為:8 出隊(duì)元素為:3
隊(duì):[4, 5, 6, 7, 8, 9, 10] 隊(duì)大小為:7 出隊(duì)元素為:4
隊(duì):[5, 6, 7, 8, 9, 10] 隊(duì)大小為:6 出隊(duì)元素為:5
隊(duì):[6, 7, 8, 9, 10] 隊(duì)大小為:5 出隊(duì)元素為:6
隊(duì):[7, 8, 9, 10] 隊(duì)大小為:4 出隊(duì)元素為:7
隊(duì):[8, 9, 10] 隊(duì)大小為:3 出隊(duì)元素為:8
隊(duì):[9, 10] 隊(duì)大小為:2 出隊(duì)元素為:9
隊(duì):[10] 隊(duì)大小為:1 出隊(duì)元素為:10
更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計(jì)有所幫助。
- java優(yōu)先隊(duì)列PriorityQueue中Comparator的用法詳解
- Java的優(yōu)先隊(duì)列PriorityQueue原理及實(shí)例分析
- java阻塞隊(duì)列實(shí)現(xiàn)原理及實(shí)例解析
- java數(shù)組實(shí)現(xiàn)隊(duì)列及環(huán)形隊(duì)列實(shí)現(xiàn)過程解析
- Java引用隊(duì)列和虛引用實(shí)例分析
- 淺談Java消息隊(duì)列總結(jié)篇(ActiveMQ、RabbitMQ、ZeroMQ、Kafka)
- Java中有界隊(duì)列的飽和策略(reject policy)原理解析
相關(guān)文章
SpringBoot中l(wèi)ogback日志保存到mongoDB的方法
這篇文章主要介紹了SpringBoot中l(wèi)ogback日志保存到mongoDB的方法,2017-11-11
Java的字符讀寫類CharArrayReader和CharArrayWriter使用示例
這篇文章主要介紹了Java的字符讀寫類CharArrayReader和CharArrayWriter使用示例,兩個類分別繼承于Reader和Writer,需要的朋友可以參考下2016-06-06
Java?精煉解讀數(shù)據(jù)結(jié)構(gòu)的順序表如何操作
程序中經(jīng)常需要將一組數(shù)據(jù)元素作為整體管理和使用,需要創(chuàng)建這種元素組,用變量記錄它們,傳進(jìn)傳出函數(shù)等。一組數(shù)據(jù)中包含的元素個數(shù)可能發(fā)生變化,順序表則是將元素順序地存放在一塊連續(xù)的存儲區(qū)里,元素間的順序關(guān)系由它們的存儲順序自然表示2022-03-03
Java中關(guān)于內(nèi)存泄漏出現(xiàn)的原因匯總及如何避免內(nèi)存泄漏(超詳細(xì)版)
這篇文章主要介紹了Java中關(guān)于內(nèi)存泄漏出現(xiàn)的原因匯總及如何避免內(nèi)存泄漏(超詳細(xì)版)的相關(guān)資料,需要的朋友可以參考下2016-09-09
解決mybatis-generator生成Mapper文件沒有Selective結(jié)尾的問題
這篇文章主要介紹了解決mybatis-generator生成Mapper文件沒有Selective結(jié)尾的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
基于Spring Boot使用JpaRepository刪除數(shù)據(jù)時的注意事項(xiàng)
這篇文章主要介紹了Spring Boot使用JpaRepository刪除數(shù)據(jù)時的注意事項(xiàng),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
詳解SpringBoot Redis自適應(yīng)配置(Cluster Standalone Sentinel)
這篇文章主要介紹了詳解SpringBoot Redis自適應(yīng)配置(Cluster Standalone Sentinel),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
Java實(shí)戰(zhàn)之實(shí)現(xiàn)在線小說閱讀系統(tǒng)
本文主要介紹了一個通過Java實(shí)現(xiàn)的在線電子書小說閱讀系統(tǒng),文中用到的技術(shù)有Layui、Springboot、SpringMVC、HTML、FTP、JavaScript、JQuery等,感興趣的可以試試2022-01-01

