Java數(shù)據(jù)結(jié)構(gòu)之有效隊列定義與用法示例
本文實例講述了Java數(shù)據(jù)結(jié)構(gòu)之有效隊列定義與用法。分享給大家供大家參考,具體如下:
/**
* @描述 有序?qū)α?
* 從任何位置插入數(shù)據(jù)都是有序的
* @項目名稱 Java_DataStruct
* @包名 com.java.stack
* @類名 Queue
* @author chenlin
*/
public class SequeQueue {
private long[] arr;
private int maxSize;// 最大空間
private int len;// 有效長度
public SequeQueue(int size) {
this.maxSize = size;
this.arr = new long[maxSize];
this.len = 0;
}
/**
*插入數(shù)據(jù)
*
* @param value
*/
public void insert(long value) {
int i;
for (i = 0; i < len; i++) {
//得到i
if (value > arr[i]) {
break;
}
}
//移動數(shù)據(jù),把前面的數(shù)據(jù)往后移動一位
for (int j = len; j > i; j--) {
arr[j] = arr[j - 1];
}
arr[i] = value;
len ++;
}
/**
* 移除數(shù)據(jù),每次移除最后一位,長度--
* 數(shù)組從0到len - 1;
*/
public long remove() {
long value = arr[len - 1];
len --;
return value;
}
/**
* 判斷是否為空
*
* @return
*/
public boolean isEmpty() {
return (len == 0);
}
/**
* 判斷是否滿了
*
* @return
*/
public boolean isFull() {
return (len == maxSize);
}
/**
* 獲得隊列的有效長度
*
* @return
*/
public int size() {
return len;
}
public static void main(String[] args) {
SequeQueue queue = new SequeQueue(8);
queue.insert(22);
queue.insert(33);
queue.insert(44);
queue.insert(534);
queue.insert(21);
queue.insert(55);
System.out.println("腳本之家測試結(jié)果:");
while (!queue.isEmpty()) {
System.out.println(queue.remove());
}
}
}
運行結(jié)果:

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計有所幫助。
- Java模擬棧和隊列數(shù)據(jù)結(jié)構(gòu)的基本示例講解
- Java數(shù)組模擬優(yōu)先級隊列數(shù)據(jù)結(jié)構(gòu)的實例
- java數(shù)據(jù)結(jié)構(gòu)與算法之雙向循環(huán)隊列的數(shù)組實現(xiàn)方法
- java 數(shù)據(jù)結(jié)構(gòu)之棧與隊列
- Java數(shù)據(jù)結(jié)構(gòu)之隊列(動力節(jié)點Java學(xué)院整理)
- Java數(shù)據(jù)結(jié)構(gòu)之循環(huán)隊列簡單定義與用法示例
- java 數(shù)據(jù)結(jié)構(gòu)中棧和隊列的實例詳解
- Java數(shù)據(jù)結(jié)構(gòu)之隊列的簡單定義與使用方法
相關(guān)文章
Idea?springboot?springCloud熱加載熱調(diào)試兩種常用方式
這篇文章主要介紹了Idea?springboot?springCloud熱加載熱調(diào)試常用的兩種方式,在項目開發(fā)的過程中,需要修改調(diào)試的時候偶每次都需要重啟項目浪費時間,下面是我整理的兩種常用的兩種方式,需要的朋友可以參考下2023-04-04
Spring項目中Ordered接口的應(yīng)用之全局過濾器(GlobalFilter)的順序控制
在Spring框架,尤其是Spring Cloud Gateway或Spring WebFlux項目中,Ordered接口扮演著重要的角色,特別是在實現(xiàn)全局過濾器(GlobalFilter)時,用于控制過濾器執(zhí)行的優(yōu)先級,下面將介紹如何在Spring項目中使用Ordered接口來管理Global Filter的執(zhí)行順序,需要的朋友可以參考下2024-06-06
Springboot 使用內(nèi)置tomcat禁止不安全HTTP的方法
這篇文章主要介紹了Springboot 使用內(nèi)置tomcat禁止不安全HTTP的方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
詳談jvm--Java中init和clinit的區(qū)別
下面小編就為大家?guī)硪黄斦刯vm--Java中init和clinit的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
SpringCloud Gateway使用redis實現(xiàn)動態(tài)路由的方法
這篇文章主要介紹了SpringCloud Gateway使用redis實現(xiàn)動態(tài)路由的方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01

