找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
感激所有對伊莉作出奉獻的人尊貴會員無限看帖不用回覆安全提問(回答) 和 永久尊貴會員 事宜
巨乳無碼fate出包王女vroverlordrpg
夜晚的水川上奈奈ge 無碼懷善堂4272356mg媚肉淫馆

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

捷運OL小姐姐

[繁]怪物轉生 Re:Mons

HAN HAN 水果攤的少女

(4月新番)[繁]Re:Mon

[繁]轉生為第七王子,

中和廣福路 不滿轎車
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 1018|回復: 3
打印上一主題下一主題

[問題]環形Queue問題[複製鏈接]

Rank: 4Rank: 4Rank: 4Rank: 4

帖子
1178
積分
7656 點
潛水值
45763 米
跳轉到指定樓層
樓主
發表於 2011-10-18 11:13 PM|只看該作者|倒序瀏覽
本帖最後由 cynthialar 於 2011-10-18 11:21 PM 編輯

請問一下,要如何解決環形Queue的一個空白位置處理?也就是說如果我的陣列大小是5個,但是因為環形Queue的關係,所以會有一格是沒存進去的,且會顯示滿的,我的code如下:                                                                                       
  1. class homeworkqueue{
  2.         public static void main(String[] args){
  3.                 queue testnumber = new queue();
  4.                 testnumber.enqueue(30);
  5.                 testnumber.enqueue(50);
  6.                 testnumber.enqueue(40);
  7.                 testnumber.enqueue(10);
  8.                 testnumber.enqueue(20);
  9.                 //testnumber.enqueue(100);
  10.                 for(int i = 0; i < 5; i++)
  11.                         System.out.println(testnumber.dequeue());
  12.         }
  13. }
  14. class queue{
  15.         public int[] number = new int[5];
  16.         public int f = 0;        //head
  17.         public int r = 0;        //tail
  18.         public void enqueue(int num){
  19.                 if(is_full() == true){
  20.                         System.out.println("It's full!!");
  21.                 }
  22.                 else{
  23.                         number[f] = num;
  24.                         f = (f + 1) % 5;
  25.                 }
  26.         }
  27.         public boolean is_full(){
  28.                 if((f + 1) % 5 == r)
  29.                         return true;
  30.                 else
  31.                         return false;
  32.         }
  33.         public int dequeue(){
  34.                 if(is_empty() == true){
  35.                         System.out.print("It's empty!!   ");
  36.                         return -1;
  37.                 }
  38.                 else{
  39.                         int tmp = number[r];
  40.                         r = (r + 1) % 5;
  41.                         return tmp;
  42.                 }
  43.         }
  44.         public boolean is_empty(){
  45.                 if(r == f)
  46.                         return true;
  47.                 else
  48.                         return false;
  49.         }
  50. }
複製代碼

我想過很多方法了,但是就是一直寫不出來,請問各位要如何去寫呢? 謝謝...
瀏覽完整內容,請先 註冊登入會員
分享分享0收藏收藏0支持支持0

使用道具檢舉

Rank: 3Rank: 3Rank: 3

帖子
3470
積分
3983 點
潛水值
62830 米
頭香
發表於 2011-10-19 12:32 AM|只看該作者
如果發覺自己無法使用一些功能或出現問題,請按重新整理一次,並待所有網頁內容完全載入後5秒才進行操作。
本帖最後由 kwj 於 2011-10-19 12:36 AM 編輯

front 指的是空的格子,也就是下一個要填入的值要放的位置
但是 rare 指的是已填資料的格子,兩個變數的定義不太一樣
所以這種狀況下 front 前進時應該是要剛好跟 rare 指到同一格時才會是 full
(因為 front+1 = rare 的話,front 此時會指的格子是空的格子,因此會出現有一格一直填不到)

不過 full 跟 empty 條件都是 front == rare 的話會有點問題...
...
瀏覽完整內容,請先 註冊登入會員
若對尊貴或贊助會員有任何疑問,歡迎向我們查詢。我們的即時通或MSN: admin@eyny.com

使用道具檢舉

Rank: 4Rank: 4Rank: 4Rank: 4

帖子
1178
積分
7656 點
潛水值
45763 米
3
發表於 2011-10-19 01:33 AM|只看該作者
若瀏覽伊莉的時侯發生問題或不正常情況,請使用Internet Explorer(I.E)。
恩恩,謝謝大哥的教導~
我再想一想您的程式邏輯~
想在問您一下,您是怎麼想到的呢??~
如何想到有這種方法??~
我想了很久都想不到,想了很多方法,轉換成程式,執行出來的東西都不如預期~
請問大哥您是如何去思考的呢??~
謝謝您~

使用道具檢舉

Rank: 3Rank: 3Rank: 3

帖子
3470
積分
3983 點
潛水值
62830 米
4
發表於 2011-10-19 07:51 AM|只看該作者
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。
本帖最後由 kwj 於 2011-10-19 07:54 AM 編輯

回復
下載: 訪客無法瀏覽下載點,請先 註冊登入會員
cynthialar


自己模擬一次 cyclic queue 依序填值進去的狀況
就會發現 front+1 == rare 的話,front 指到的最後一格會填不到東西
(邏輯上其實 front +1 == rare 應該是在插入完以後才檢查
...
瀏覽完整內容,請先 註冊登入會員
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部