欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門教程網(wǎng)!

Java編程

當(dāng)前位置:主頁(yè) > 軟件編程 > Java編程 >

java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:Java編程|點(diǎn)擊: 次

隊(duì)列是一種特殊的線性表,只允許在表的前端進(jìn)行刪除,在表的后端進(jìn)行插入,表的前端稱為(front)隊(duì)頭,表的后端稱為(rear)隊(duì)尾。

所以隊(duì)列跟生活的場(chǎng)景很是相似,在電影院買電影票,人們排成一排,第一個(gè)人進(jìn)入隊(duì)尾最先到達(dá)隊(duì)頭后買票進(jìn)入影院,后面排隊(duì)的人按照排隊(duì)的次序買到票后進(jìn)入影院。

所以 隊(duì)列是一種先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu)(FIFO)。

編程實(shí)現(xiàn)對(duì)循環(huán)鏈隊(duì)列的入隊(duì)和出隊(duì)操作。

⑴根據(jù)輸入的隊(duì)列長(zhǎng)度n和各元素值建立一個(gè)帶頭結(jié)點(diǎn)的循環(huán)鏈表表示的隊(duì)列(循環(huán)鏈隊(duì)列),并且只設(shè)一個(gè)尾指針來(lái)指向尾結(jié)點(diǎn),然后輸出隊(duì)列中各元素值。

⑵將數(shù)據(jù)元素e入隊(duì),并輸出入隊(duì)后的隊(duì)列中各元素值。

⑶將循環(huán)鏈隊(duì)列的隊(duì)首元素出隊(duì),并輸出出隊(duì)元素的值和出隊(duì)后隊(duì)列中各元素值。

當(dāng)隊(duì)列的插入數(shù)據(jù)時(shí),Rear箭頭一直往上走,插入到表的最大下標(biāo)的位置后停止。在移除數(shù)據(jù)的時(shí)候,front箭頭也會(huì)一直往上走。

這可能跟現(xiàn)實(shí)中的人們?cè)陔娪霸嘿I電影票的情況有點(diǎn)不符合,一般是買完票,人就往前走,繼續(xù)買票,隊(duì)伍總是向前移動(dòng)的。

在計(jì)算機(jī)中,隊(duì)列每刪除一個(gè)數(shù)據(jù)項(xiàng)后,其他數(shù)據(jù)也可以繼續(xù)往移動(dòng),但如此一來(lái),處理很大的數(shù)據(jù)的時(shí)候,這樣做的效率很低下,因?yàn)槊看蝿h除一個(gè)數(shù)據(jù)就要將剩余的所有數(shù)據(jù)往前移動(dòng)。

在刪除數(shù)據(jù)的時(shí)候,隊(duì)頭(Front)前面的位置就會(huì)留空,但由于隊(duì)尾(Rear)和隊(duì)頭(Front)這兩個(gè)箭頭都一直往上走,所以沒(méi)能繼續(xù)利用到前面空單元的存儲(chǔ)空間。

為了避免隊(duì)列不滿卻不能繼續(xù)插入新數(shù)據(jù)的情況,解決隊(duì)列能循環(huán)利用的方法就是,當(dāng)Rear箭頭和Front箭頭到達(dá)最大下標(biāo)的位置后,重新將它的位置移動(dòng)到, 表的最初始的位置。

這個(gè)就是------循環(huán)隊(duì)列:

package DataStructure;
 
/**
 * Created by Hubbert on 2017/11/11.
 */
public class Queue {
 
  private int [] arr ;
  private int front ; //隊(duì)頭指針
  private int rear ; //隊(duì)尾指針
  private int nItems ;//隊(duì)列中的個(gè)數(shù)
  private int maxSize;//隊(duì)列長(zhǎng)度
 
  //使用構(gòu)造函數(shù)進(jìn)行初始化
  public Queue( int maxSize ){
    this.maxSize = maxSize ;
    this.arr = new int [this.maxSize];
    this.nItems = 0 ;
    this.front = 0;
    this.rear = -1 ;
  }
 
  public boolean isFull(){
    return (nItems == maxSize);//判斷隊(duì)列是否已滿
  }
 
  public boolean isEmpty(){
    return (nItems == 0);//判斷隊(duì)列是否為空
  }
 
  //插入
  public void insert( int number ){
    if(!isFull()){
      //處理循環(huán)隊(duì)列
      if( rear == (maxSize -1)){
        rear = -1;
      }
      arr[++rear] = number ;
      nItems++;
    }else{
      System.out.println("The Queue is full!!");
    }
  }
 
  //刪除
  public int remove(){
    if(!isEmpty()){
      //處理循環(huán)隊(duì)列
      if( front == maxSize ){
        front = 0;
      }
      nItems--;
      return arr[front++];
 
    } else {
      System.err.println ("The Queue is Empty!!");
      return -1;
    }
  }
 
  public static void main(String [] args){
    Queue queue = new Queue(5);
    queue.insert(22);
    queue.insert(33);
    queue.insert(44);
    queue.insert(55);
    queue.insert(66);
 
    System.out.println("-----------先刪除隊(duì)列中前兩個(gè)數(shù)據(jù)------------");
    System.out.println("Front--->Rear:");
    for( int i =0 ; i < 2 ; i++ ){
      System.out.print(queue.remove() + " ");
    }
 
    System.out.println("");
    System.out.println("-----------繼續(xù)使用隊(duì)列------------");
    System.out.println("Front--->Rear:");
    queue.insert(1);
    queue.insert(2);
    while (!queue.isEmpty()){
      System.out.print(queue.remove() + " ");
    }
  }
}

結(jié)果如下:

總結(jié)

以上就是本文關(guān)于java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:

java編程實(shí)現(xiàn)優(yōu)先隊(duì)列的二叉堆代碼分享

Java編程用兩個(gè)棧實(shí)現(xiàn)隊(duì)列代碼分享

如有不足之處,歡迎留言指出。期待您的寶貴意見(jiàn)。

上一篇:Java編程—在測(cè)試中考慮多態(tài)

欄    目:Java編程

下一篇:Java編程小實(shí)例—數(shù)字時(shí)鐘的實(shí)現(xiàn)代碼示例

本文標(biāo)題:java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例

本文地址:http://mengdiqiu.com.cn/a1/Javabiancheng/8428.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有