真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java如何實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

小編給大家分享一下java如何實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)網(wǎng)站建設(shè)由有經(jīng)驗(yàn)的網(wǎng)站設(shè)計(jì)師、開發(fā)人員和項(xiàng)目經(jīng)理組成的專業(yè)建站團(tuán)隊(duì),負(fù)責(zé)網(wǎng)站視覺設(shè)計(jì)、用戶體驗(yàn)優(yōu)化、交互設(shè)計(jì)和前端開發(fā)等方面的工作,以確保網(wǎng)站外觀精美、做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)易于使用并且具有良好的響應(yīng)性。

什么是隊(duì)列結(jié)構(gòu)

一種線性結(jié)構(gòu),具有特殊的運(yùn)算法則【只能在一端(隊(duì)頭)刪除,在另一端(隊(duì)尾)插入】。

分類:

順序隊(duì)列結(jié)構(gòu)
鏈?zhǔn)疥?duì)列結(jié)構(gòu)

基本操作:

入隊(duì)列
出隊(duì)列 

給出一些應(yīng)用隊(duì)列的場(chǎng)景

1):當(dāng)作業(yè)被送到打印機(jī)的時(shí)候,就可以按到達(dá)的順序排起來,因此每一份作業(yè)是隊(duì)列的節(jié)點(diǎn)。

2):售票口的人買票的順序的按照先來先買的順序售票。

3):當(dāng)所有的終端被占用,由于資源有限,來訪請(qǐng)求需要放在一個(gè)隊(duì)列中等候。

隊(duì)列是先進(jìn)先出的! 

我們?cè)O(shè)置一個(gè)叫做LinkQueue的泛型集合類,該類里面有 Node 作為內(nèi)部類(作為節(jié)點(diǎn)用),它包含了泛型元素和下一個(gè)node節(jié)點(diǎn)的指向next(Node)。

在Linkqueue的里面設(shè)置隊(duì)列頭指針 front和隊(duì)列尾指針rear,長(zhǎng)度size=0;我們先設(shè)置一個(gè)構(gòu)造器LinkQueue(),用來初始化這兩個(gè)指針節(jié)點(diǎn),當(dāng)然,剛開始初始化的時(shí)候 這兩個(gè)指針僅僅是一個(gè)節(jié)點(diǎn)而已,里面的data是空的,我們還讓這兩個(gè)指針相等。

//鏈的數(shù)據(jù)結(jié)構(gòu) 
 private class Node{ 
 public T data; 
 public Node next; 
 //無參構(gòu)造函數(shù) 
 public Node(){} 
  
 public Node(T data,Node next){ 
  this.data=data; 
  this.next=next; 
 } 
 } 
 //隊(duì)列頭指針 
 private Node front; 
 //隊(duì)列尾指針 
 private Node rear;
public LinkQueue(){
	Node n=new Node(null,null);
	n.next=null;
	front=rear=n;
}

當(dāng)我們向該隊(duì)列添加元素的時(shí)候,就會(huì)生成一個(gè)新的節(jié)點(diǎn),其data就是你要加的元素,(當(dāng)添加一個(gè)節(jié)點(diǎn)時(shí),該節(jié)點(diǎn)就是隊(duì)尾指針指向的最后的節(jié)點(diǎn),一直排在最后),所以隊(duì)尾rear.next=newNode(“新創(chuàng)建的節(jié)點(diǎn)”).這是第一個(gè)節(jié)點(diǎn),也是最后一個(gè)節(jié)點(diǎn),所以front.next=newNode.然后我們?cè)僮宺ear=newNode(不斷更新)。

public void enqueue(T data){ 
 //創(chuàng)建一個(gè)節(jié)點(diǎn) 
 Node s=new Node(data,null); 
 //將隊(duì)尾指針指向新加入的節(jié)點(diǎn),將s節(jié)點(diǎn)插入隊(duì)尾 
 rear.next=s; 
 rear=s; 
 size++; 
 }

當(dāng)隊(duì)列出隊(duì)的時(shí)候,還記得我們有一個(gè)Node是front.next=newNode 嗎?這就是第一個(gè)節(jié)點(diǎn)。先暫且把它叫做p,所以p.next=第二個(gè)節(jié)點(diǎn),這時(shí)我們?cè)侔裦ront.next=p.next;這樣頭指針就指向了第二個(gè)元素(每一次調(diào)用的時(shí)候隊(duì)列頭指針指會(huì)發(fā)生變化)。

public T dequeue(){ 
 if(rear==front){ 
  try { 
  throw new Exception("堆棧為空"); 
  } catch (Exception e) { 
  e.printStackTrace(); 
  } 
  return null; 
 }else{ 
  //暫存隊(duì)頭元素 
  Node p=front.next; 
  T x=p.data; 
  //將隊(duì)頭元素所在節(jié)點(diǎn)摘鏈 
  front.next=p.next; 
  //判斷出隊(duì)列長(zhǎng)度是否為1 
  if(p.next==null) 
  rear=front; 
  //刪除節(jié)點(diǎn) 
  p=null; 
  size--; 
  return x; 
 } 
 }

到此為止,隊(duì)列的核心操作就完畢了,剩下的比如說size(長(zhǎng)度),isEmpty(是否為空),就不在說了。(因?yàn)樘?jiǎn)單了!)

具體源碼如下:

public class LinkQueue {
	//鏈的數(shù)據(jù)結(jié)構(gòu) 
	private class Node{
		public T data;
		public Node next;
		//無參構(gòu)造函數(shù) 
		public Node(){
		}
		public Node(T data,Node next){
			this.data=data;
			this.next=next;
		}
	}
	//隊(duì)列頭指針 
	private Node front;
	//隊(duì)列尾指針 
	private Node rear;
	//隊(duì)列長(zhǎng)度 
	private int size=0;
	public LinkQueue(){
		Node n=new Node(null,null);
		n.next=null;
		front=rear=n;
	}
	/** 
 * 隊(duì)列入隊(duì)算法 
 * @param data 
 * @author WWX 
 */
	public void enqueue(T data){
		//創(chuàng)建一個(gè)節(jié)點(diǎn) 
		Node s=new Node(data,null);
		//將隊(duì)尾指針指向新加入的節(jié)點(diǎn),將s節(jié)點(diǎn)插入隊(duì)尾 
		rear.next=s;
		rear=s;
		size++;
	}
	/** 
 * 隊(duì)列出隊(duì)算法 
 * @return 
 * @author WWX 
 */
	public T dequeue(){
		if(rear==front){
			try {
				throw new Exception("堆棧為空");
			}
			catch (Exception e) {
				e.printStackTrace();
			}
			return null;
		} else{
			//暫存隊(duì)頭元素 
			Node p=front.next;
			T x=p.data;
			//將隊(duì)頭元素所在節(jié)點(diǎn)摘鏈 
			front.next=p.next;
			//判斷出隊(duì)列長(zhǎng)度是否為1 
			if(p.next==null) 
			  rear=front;
			//刪除節(jié)點(diǎn) 
			p=null;
			size--;
			return x;
		}
	}
	/** 
 * 隊(duì)列長(zhǎng)隊(duì) 
 * @return 
 * @author WWX 
 */
	public int size(){
		return size;
	}
	/** 
 * 判斷隊(duì)列是否為空 
 * @return 
 * @author WWX 
 */
	public Boolean isEmpty(){
		return size==0;
	}
}

以上是“java如何實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


新聞名稱:java如何實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu)
本文鏈接:http://weahome.cn/article/pepcsi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部