java實現隊列實現方法

來源:互聯網
上載者:User

隊列是一種重要的資料結構,主要應用是資源的排隊(例如印表機),需要注意的是要利用迴圈資料來儲存資料
調用代碼

public static void main(string[] args){
  queue queue=new queue();
  for(int i=0;i<15;i++){
   queue.enqueue("sunzhenxing"+i);
  }
  system.out.println(queue);
  system.out.println(queue.getsize());
  system.out.println("----------------------");
  for(int i=0;i<10;i++){
   queue.dequeue();
  }
  system.out.println(queue);
  system.out.println(queue.getsize());
  system.out.println("----------------------");
  for(int i=0;i<5;i++){
   queue.enqueue("sunhailong"+i);
  }
  system.out.println(queue);
  system.out.println(queue.getsize());
}


java類檔案
class queue {
 private int front;
 private int back;
 private int size;
 private object[] data;
 
 public queue(){
  data=new object[10];
 }
 
 public int getsize(){
  return size;
 }
 
 public object dequeue(){
  object o=null;
  if(size>0){
   size--;
   o=data[front];
   data[front]=null;
   front=(front>data.length-1)?0:front+1;
  }
  return o;
 }
 
 public void enqueue(object o){
  if(size>=data.length){
   object[] newdata=new object[data.length*2];
   for(int i=0;i<data.length;++i){
    newdata[i]=data[i];
   }
   data=newdata;
  }
  data[back]=o;
  back++;
  size++;
 }
 
 public string tostring(){
  stringbuffer str=new stringbuffer();
  for(int i=0;i<data.length;i++){
   object o=data[i];
   if(o!=null){
    str.append(o+" ");
   }   
  }
  return str.tostring();
 }
}


隊列是一種重要的資料結構,在排隊論和演算法設計中有很重要的應用,其實隊列也是一種鏈表,它只允許在表的始端出表(dequeue),在表的末端入表(enqueue),上邊是隊列的java實現。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.