chapter 3 教材.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
chapter 3 教材

資料結構 第三章 堆疊與佇列 大綱 第一節 堆疊 第二節 佇列 第一節 堆疊 一、定義 堆疊是一個有序串列,所有的加入(insert)與刪除(delete)動作均是在堆疊的頂端(top)進行,具有先進後出(FILO)或後進先出(LIFO)的特性。 第一節 堆疊 二、應用 1. 副程式的呼叫及返回處理。 2. 遞迴程式的呼叫及返回處理。 3. 算術式的轉換。 4. 二元樹的走訪。 5. 圖形的走訪。 6. 中斷的處理。 第一節 堆疊 三、堆疊的工作定義 1. CREATE(S):建立一個空的堆疊。 2. PUSH(data, S):將資料加入堆疊的頂端。 3. POP(S):傳回堆疊頂端的資料,並將該筆資料 自堆疊中刪除。 4. TOP(S):傳回堆疊頂端的資料,但不將該筆資 料自堆疊中刪除。 5. EMPTY(S):若堆疊內已無任何資料,就傳回真 (true),否則就傳回假(false)。 第一節 堆疊 四、加入及刪除資料的演算法 將一筆資料加入堆疊中的演算法: Procedure PUSH(data, stack, n, top) If (topn) then Call STACK-FULL( ) Else stack(top)←data top←top+1 end if end PUSH 第一節 堆疊 (1) data:代表欲加入堆疊中的資料。 (2) stack:是一個指向堆疊起點的指標(pointer)。 (3) n:記錄堆疊的大小。 (4) top:是一個指向堆疊頂端的指標,亦即指向堆疊中下一個可以再存放資料的指標。 (5) STACK-FULL( ):是一個錯誤警告副程式,用來表示現在的堆疊已經滿了,無法再做加入資料的動作了。 (6) ‘←’:表示將右邊的資料存入左邊所指的位置,所以“stack(top)←data”表示將資料data存入stack + top所指的位置中。 第一節 堆疊 自堆疊中取出一筆資料,並刪除該筆資料的演算法: Procedure POP(stack, data, top) if ( top=1) then Call STACK_EMPTY( ) else top ← top-1 data ← stack(top) end if end POP 第一節 堆疊 STACK_EMPTY( )是一個錯誤警告副程式,用來表示現在的堆疊已經是空的,無法再做取出或刪除資料的動作了。 註:以上兩個演算法PUSH( )及POP( ),若陣列起始編碼是從1開始,則堆疊可以加入或刪除n筆資料;但若是從零開始,則演算法POP( )中之if判斷式須修改成if (top=0) then call STACK-EMPTY( ),如此即可加入或刪除n+1筆資料了。 第二節 佇列 一、定義 佇列是一個有序串列 (ordered list),所有的加入與刪除分別發生在串列的不同端,加入的一端稱為後端 (rear),而刪除的一端稱為前端 (front),具有先進先出 (FIFO) 的特性。 第二節 佇列 二、應用 1. 作業系統的工作排程。 2. 電腦的模擬(simulation)程式。 3. 輸出入工作緩衝區(buffer)。 第二節 佇列 三、佇列的工作定義 1. CREATE(Q):建立一個空的佇列。 2. ADDQ(data, Q):將資料加入佇列的尾端(rear)。 3. DELETEQ(Q):傳回佇列前端(front)的資料,並將 該筆資料自佇列中刪除。 4. FRONT(Q):傳回佇列前端的資料,但不會將該筆 資料自佇列中刪除。 5. EMPTY(Q):若佇列為空的(empty),代表佇列內已 無任何資料,因此就傳回真(true);否則就傳回假 (false),代表佇列不為空的,亦即佇列內尚有資料。 第二節 佇列 四、加入及刪除資料的演算法 將一筆資料加入佇列中的演算法: Procedure ADDQ(data, Q, n, rear) if (rearn) then ca

文档评论(0)

peain + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档