資料結構 7-1 陣列 7-2 鏈結串列 7-3 堆疊和佇列 7-4 樹狀結構.

Slides:



Advertisements
Liknende presentasjoner
 練習 XSL 程式的撰寫 › 了解 XSL 的轉換意義  在 XML 文件中宣告 XSL › fhwang XML Programming 10.
Advertisements

ヴァンデグラフでの回路図. VME Discri V895 ECL Logic Delay 200ns VME TDC V775 HIME Analog Delay 200ns VME QDC V792 LEMO BNC FLAT 32ch 16ch x2 32ch BNC - LEMO 変換 A.
6218 白盛弘. 北極熊的家 8&p=%E5%8C%97%E6%A5%B5%E7%86%8A&fr2=tab-web&fr=yfp-s.
鼾音訊號測量計畫 執導老師 : 侯春茹 老師 組員 : 金雍庭 胡庭恩 林承葦 賴彥亨. 目錄 訊號的簡介 ▫ 臨床應用 ▫ 量測部位與方法 ▫ 訊號特徵 訊號處理流程 鼾聲量得訊號.
いまこれが熱い 米国の Web2.0 サービス CNET Japan Innovation Conference 2006 Autumn データセクション(株) 橋本大也 (株)ネットエイジグループ チーフエバンジェリスト.
LHU_ME 魏慶隆 李瑞宗老師 零件組立之基本操作  零件組立之步驟  Component  Assembly  [ 選取零件 ]  定位  定位指令說明 定位指令說明.
2009 Summer Camp MRP 物料需求規劃 演講者:黃怡勳.
是 1. 全球暖化是真的嗎 ? 人類 2. 是什麼原因又是誰造成的 ? 破壞基本生態的穩定 3. 氣候改變對地球及我們有什麼影響 ? 最貧窮、最低窪、最熱的國家受害最大,但是每個人都無法倖免 於難 4. 誰會受到最大的衝擊 ? 發展與氣候變化 國際商務學系 A 林宜 如.
弊社取り扱いスマートホン媒 体 Avarice Yell inc.. スマートフォン取り扱い アドネットワーク&リスティング Avarice Yell inc.
線形代数学.
Order To Cash 主講人:蓋冠宇.
芬蘭 - 進口 黃硯翎 A 國花:鈴蘭. 芬蘭進口 黃硯翎 A 國家印象代表圖 ~~ 桑拿浴.
要求プロセスの数量化 要求工学 WG in 宇和島 要求獲得 要求記述 要求検証 要求管理 Stakeholder の識別 要求抽出 ネゴシエーション モデル化 記述 記述の解析 テスト・実行 要求工学プロセス.
人类进步与环境代价 —— 绿色化学关注的问题 孙立广 (中国科技大学极地环境研究室). 一、引言 从绿色革命到绿色科技 20 世纪 60 年代 “ 绿色革命 ” 的结果: 农作物高产 高产水稻品种 化肥大量使用烈性农药 水土污染、 肥力降低 水荒.
小沢研究室紹介 大学院を志す人のために. 素粒子・原子核物理学とは? 自然を支配する基本法則はどのようなものか 物質を構成する究極の要素は何か 宇宙はなぜ現在の姿になっているのか 宇宙にはどのような物質が存在し、それはどのように作られ たのか 2000年以上も前から人類の探究心を駆り立ててやまないこれら.
第 14 章 SQL 語言處理資料庫 14-1 SQL 語言的基礎14-1 SQL 語言的基礎 14-2 SQL 資料庫查詢指令14-2 SQL 資料庫查詢指令 14-3 SQL 聚合函數14-3 SQL 聚合函數 14-5 SQL 語言的資料庫操作14-5 SQL 語言的資料庫操作.
HTML + Dreamweaver 學術 課程. 甚麼是 HTML ? HTML 全名是 Hyper Text Markup Language ﹐ 是電腦語言的一種。這種電腦語言是可透過瀏 覽軟件 (Browser - Internet Explorer, Netscape) 翻譯出來﹐翻出來的就是我們看到的.
1 © 2011 台灣培生教育出版 (Pearson Education Taiwan). 2 學習目標 1. 了解收益管理在供應鏈中所扮演的角色。 2. 界定出何種收益管理做法具有效率的情況。 3. 描述制定收益管理決策時,需要考量的取捨條 件。
雜 湊 表.
中国法律检索系统. 数据库介绍 系统收录 22 个相对独立但又互通互联的法律信息数据库:《中 国法律法规规章司法解释全库》、《中国地方法规规章库》、 《港澳台法律库》、《中华人民共和国条约库》、《外国与国际 法律库》、《法律文书样式库》、《最高人民法院公报案例库》、 《中国法院裁判文书数据库》、《合同范本数据库》、《仲裁裁.
1 Understanding and Constructing Approaches to Teaching 第二講 教案設計初探 林碧霞博士 Lam Bick Har©2006.
2005 年 1 月 18 日台灣視障用數位典藏之 語音檢索系統 1 「貓頭鷹」 ~ 台灣視障用數位典藏 之語音檢索系統 93 年數位典藏創意加值計畫心得交流 「貓頭鷹」 ~ 台灣視障用數位典藏 之語音檢索系統 93 年數位典藏創意加值計畫心得交流 報告人 : 唐傳義 張智星 國立清華大學資工系教授.
EQ與情緒管理 資料截自清涼音出版社(VCD AV13)-張錦貴教授.
计算器的使用 CASIO 系列. 可编程序计算器使用方法简介 CASIO fx-350ms.
2009 年世界地球日 您必須知道的全球暖化現況 為倡導保護地球,國際上訂定每年的四月二十四 日世界地球日。今年活動主軸是大家一齊來防止地 球暖化。在那一天,世界各地愛護環境的人,不但 要用行動展現「熱愛地球」實力,也要依推動者的 建議,一齊穿上藍色系列的衣裝出門,以展現退暖.
第八組  M 林秋香 M 顧家容  M 裴方南 M 陳黃慶璃  M 賴盈如 M 葉芳如.
A02 通識教育課程 ( 二年級 ) 生物化學、醫學生涯、醫學研究方法 金髮小蜜的故事 教案代碼: 9622A02-4.
企業員工訓練與發展 7.1 訓練與發展的意義與系統化程序 7.2 訓練需求分析 7.3 訓練的設計與準備 7.4 非管理職員工的訓練方法
Word Word 2000 的操作環境 功能表列 尺規 垂直捲軸 顯示模式 瀏覽物件鈕 水平捲軸 狀態顯示列 內文區域 關閉鈕 放到最大鈕 縮到最小鈕標題列 插入點.
專業‧互相尊重‧開拓者精神 台北大學投影機案 教 育 訓 練. Agenda § 使用前注意說明 § 控制面板操作說明 § 投影布幕之使用 § 關機操作順序說明 § 簡易故障排除 § 問題討論時間.
教學助理培訓課程 部落格城市管理 講師 : 程如晞.
土地使用管制 2008 年 10 月 23 日. 政府導向 社會目標 比較真實市場 與社會目標 規劃 政策 政府 市場 失靈 土地市場 財產市場 傳統福利經濟學觀點下的規劃理念 設計 引起被發現 去改變.
講述教學法案例.
11 類別化程式 11.1 結構與類別 結構與類別 結構化程式設計 結構化程式設計 物件導向程式設計 物件導向程式設計 程式類別 (class)
1987 年的 聖誕節前夕,當我正在美國進修 資管碩士學位時,有一門課要求我們四個 人一組到企業去實際幫他們寫系統,由於 同組的另外三個老美對系統開發都沒什麼 概念,所 以我這位組長只好重責一肩挑起, 幾乎是獨立完成了所有的工作。終於拖到 了結案,廠商及老師對我們的(其實是我 的)系統都相當滿意。第二天我滿懷希望.
MPI 分布内存并行 程序开发. 第四章 点对点通信函数 第四章 点对点通信函数 传送机制(两种): 阻塞方式,它必须等到消息从本地送出之后才可 以执行后续的语句,保证了缓冲区等资源的可再 用性; 非阻塞方式,它不须等到消息从本地送出就可以 执行后续的语句,但非阻塞调用的返回并不保证 资源的可再用性。
類比式語言教室材使用說明會 東吳大學語言教學中心. 說明會內容 l 開(關)機步驟 l 操作畫面說明:聲音頻道、影像頻道 l 操作示範: DVD 影片、教學電腦、錄影 帶、 3D 教材提示機、錄音帶 l 耳機互動:監聽、對話、分組、示範 l 錄音功能:對拷、學生自主拷貝.
4.1 單向鏈結串列 4.2 堆疊的加入與刪除 4.3 佇列的加入與刪除 4.4 其他型式的佇列
香港科技大学学生会 语言学会 广东话课程 2007 第二节 自我介绍. 温习 1 早晨 返学 放学 jou2 san4 faan1 hok6 fong3 hok6 你上几点堂? nei3 seung5 gei2 dim2 tong4 你食左早餐未呀? nei5 sik6 jo2 jou2 can1.
江西省委组织部远教办 (地 市 视 频 会 议 系 统)培训 江西省委组织部远教办 (地 市 视 频 会 议 系 统)培训 主讲人:饶斌.
口腔良性腫瘤 蔡政峰醫師.
加藤ゼミへのエントリー (ゼミ活動の際のスタッフプレート ♪ ). エントリーシート方式 面談 2〜3名で、 10 〜 20 分の面談をします。 エントリーシート を提出してもらいます。
民意型態 民意調查 蔡佳泓.  True Believers— 真實信仰者,具有意識形態  Concerned Citizen— 關心政治者,對於政治 有興趣.
國立台北科技大學 工業工程與管理所碩士論文 網頁行銷美學與顧客體驗關鍵因素之研究 指導教授:羅啟源教授 研究生:黃金圳甄
克里斯提安.齊瑪曼 (Krystian Zimerman) 齊瑪曼  出生於波蘭扎布熱  父親啟蒙開始學習鋼琴  1963 年在卡托維治音樂院師從 楊辛斯基 楊辛斯基  1975 年贏得蕭邦國際 鋼琴大賽第一名,當時年僅十九歲 鋼琴大賽第一名,當時年僅十九歲.
林綺雲 國立台北護理學院 生死教育與輔導研究所教授(創所所長)
財務管理概論 劉亞秋‧薛立言 合著 (東華書局, 2007)
行銷學 marketing: an introduction
授課老師:吳有龍 教授 報告學生:王智鳳 學號: G 優使性 - 需求分析及高階設計 優使性 - 需求分析及高階設計.
嵌入式操作系统 陈香兰 助教:毛熠璐、吴昊 Spring 2008.
報告人:李克強 校內分機: : 圖書館電子資源利用講習.
台北大學統計系 汪群超 資料庫系統 汪群超02/22/2000. 資料庫資訊系統實例 貿易訂單管理 貿易訂單管理 職棒球員攻守紀錄 職棒球員攻守紀錄 圖書資訊系統 圖書資訊系統 VCD/DVD 租借管理系統VCD/DVD 租借管理系統 網路商場 網路商場.
吉林大学远程教育 共 计: 48 学时 主讲单位: 吉林大学基础医学院 药 理 教 研 室 第 二 十 七 讲 主讲教师: 李 晶.
第二节 鞭毛菌亚门真菌(Mastigomycotina)
1 《通信原理》总结 2 通信原理是通信学科的理论基础, 以调制和编码技术为核心,着重介绍 传输信号的形成和接收方式,进行理 论分析与性能评价。 可靠性 模拟系统的噪声性能分析 数字系统的误码性能分析 差错控制编码 有效性 各种信道复用方式: TDM , FDM , CDMA 等。
UClinux 简介 Embedded operating system μClinux uClinux 是应用于嵌入式设备的最著名、应用 最广泛一个 Linux 发行版本,它也是一个开放 源码的项目, uClinux 的源代码和开发工具可 以免费从
偵錯技術.
-- Homo Sapien -- DESIGN For A Especial Spirit Group : b 陳姵華 b 蘇若 喬 b 王淑燕 b 柳柏亙.
第 13 章 檔案與資料夾處理 13-1 檔案與資料夾操作 13-1 檔案與資料夾操作 13-2 循序檔案的文字檔案讀寫 13-2 循序檔案的文字檔案讀寫 13-3 隨機檔案的處理 13-3 隨機檔案的處理 13-4 二進位檔案的讀寫 13-4 二進位檔案的讀寫 13-5 檔案對話方塊 13-5 檔案對話方塊.
CorelDRAW X4 平面设计半月通 ─ 电子教案 第二章 手绘和形状工具的使用 本章导读 本章要点本章任务 上机实训.
DESIGNER. 創作主題: FANTASY 幻想旅程 報名方式:傳真報名 ─ 報名 ─ ( 報名表請向系辦索取或至「校園比賽 Facebook 粉絲團」下載 ) 競賽組隊:分為大專組與高中職組 報名隊伍以個人或團體組隊參加皆可,每人以報名一組為限.
有机化学 主讲教师 霍文兰 教 材 高鸿宾 主编. Chapter 5 alkynes alkadiene.
第六章 纱线和织物的基本知识.
2015 年学员操作手册 奥鹏教育. C o nt en ts 目录目录 平台首页简介 1 个人工作室 2 学习任务 3 研修活动 4 坊内答疑 5 资源分享 6.
现代陶艺 现代陶艺 -- 泥条盘筑成型 -- 泥条盘筑成型 任课教师 赵 芳. 一、陶艺的概念 所谓陶艺,它泛指陶瓷日用品,陈设品的造型、釉色 和装饰等所呈现的艺术特点,也专指陶器之中的艺术陶器 和瓷器中的艺术瓷。 陶艺作品是典型的工艺美术,它既有其他工艺美术的 共性,更有着区别于其他工艺美术的质的规定性。任何一.
野生动物保护系列讲座. 我们中国人自称为龙的传人。清朝 光绪年代,总税务司发行 “ 大龙邮票 ” , 大龙邮票的最早发行日期被认为在 1878 年 7 月 24 日至 8 月 1 日之间。 龙文化 —— 龙年.
3dsmax 基本工具介绍 3dsmax 基础建模类型介绍 多边形建模操作技巧 材质基础知识介绍 讲授: 8 节 实训: 8 节 掌握游戏 3D 制作工具 —3dsmax 的基本工作原理。
XXX 交流电路的功率. 一、正弦交流电路功率的基本概念 设正弦交流电路的总电压 u 与总电流 i 的相位差 ( 即阻 抗角 ) 为  ,则电压与电流的瞬时值表达式为 u = U m sin(  t   ) , i = I m sin(  t) 瞬时功率为 p = ui = U m I m.
Utskrift av presentasjonen:

資料結構 7-1 陣列 7-2 鏈結串列 7-3 堆疊和佇列 7-4 樹狀結構

7-1 陣列 表示一系列相同型態的資料,如:學號1號到5號同學的數學成績 範例宣告: 陣列內資料的指定可利用註標,範例如下:

陣列的順序 邏輯順序:也就是註標的順序 實體順序 :在記憶體裡的順序,示意圖如下: 陣列的實體順序,也是由註標小的依序排到註標大的,正好和邏輯順序一樣;所以,某一個註標在記憶體的位置可以很快決定出來,其公示如下(假設一個整數的大小為4 bytes): Score[0] Score[1] Score[2] Score[3] Score[4] 80 70 60 90 95

二維陣列 應用範例:同時表示5位同學的數學成績和英文成績 範例宣告: 所有同學的數學成績可以記錄在 “scores” 二維陣列的第一列,英文成績可以記錄在 “scores” 二維陣列的第二列,每個同學這兩科成績的對應註標如下所示: 表7-2:二維陣列的註標對應 學號1 學號2 學號3 學號4 學號5 數學成績 scores[0][0] scores[0][1] scores[0][2] scores[0][3] scores[0][4] 英文成績 scores[1][0] scores[1][1] scores[1][2] scores[1][3] scores[1][4]

二維陣列的實體順序 以列為主:先存放好第一「列」的元素,接著再存放第二「列」,依此類推 其示意圖如下: 其公式如下: 第一列 第二列 [0][0] [0][1] [0][2] [0][3] [0][4] [1][1] [1][2] [1][3] [1][4] 80 70 60 90 95 65 75 85 81 74

以欄為主:先存放好第一「欄」的元素,接著再存放第二「欄 」,依此類推,其公式如下:

7-2 鏈結串列 front 3 5 null 可表示不確定大小或會動態增減的資料 由一個個節點所組成,其資料型態宣告如下: 鏈結串列範例如下: front 3 5 null

指標變數 根據C語言的語法,在宣告一個變數時前面加上符號「*」,即為指標變數 指標變數記錄的值是資料在記憶體裡的位置 取出資料的方法 在變數前面加上符號   ,如      會傳回該節點在 “data”欄位的值 在變數後面加上箭頭    ,如 空指標 * *front.data “” frontdata 表示為 “null” 通常用來表示一個串列的結束

鏈結串列程序(一) 把一個新的節點加入到鏈結串列的起點 程序 “insert” 定義如下:

程序insert執行步驟 front 7 3 5 null 執行「insert(front, 7)」的步驟 利用 “malloc”函數建立一個新的節點,並利用局部變數 “temp”指到該節點 把數值 “7”指定給節點 “temp”的欄位 “data” 將節點 “temp”的欄位 “next” 指到 “p”所指到的節點,也就是串列的第一個節點 將參數 “p”(也就是 “front”)指到新建立的節點 執行之後的鏈結串列如下所示: front 7 3 5 null

鏈結串列的實體順序 鏈結串列的實體順序和邏輯順序無關。 原因:利用函數 “malloc”向系統要一塊記憶體的空間時,系統會根據當時記憶體哪裡有空位,而把地址回傳 “可能的”實體順序示意圖: 要取出鏈結串列的某一個節點,只能依循事先建立好的指標,一一探訪中間經過的節點 第二個節點 第一個節點 第三個節點 3 L5 7 L1 5 Null L2 L3 L4 L6

鏈結串列程序(二) 把一個鏈結串列內所有節點的內容值依照邏輯順序列出來 程序 “print_linked_list” 定義如下:

鏈結串列程序(三) 把第一個參數 “p”指到的鏈結串列的起始節點,變成第二個參數 “q” 指到的鏈結串列的起始節點 程序 “changehead” 定義如下:

程序changehead的執行步驟示意圖

7-3 堆疊和佇列 放入 取出 (a) 5 (b) 5 4 4 3 3 2 2 1 1 堆疊 後進先出 先進後出 右圖範例 最早放進去的1號球會在球桶的最下方,而最後放進去的5號球會在球桶的最上方 要用球時,首先拿到的是球桶最上方的5號球,最後才會拿到1號球 (a) 5 (b) 5 4 4 3 3 2 2 1 1 圖7-3 堆疊示意圖

以陣列實作堆疊 宣告一個一維整數陣列來存放堆疊中的元素 定義整數變數 “top”,對應到最上層元素的註標 定義將資料放入堆疊的程序 “push” 定義將資料從堆疊取出的程序 “pop”

佇列 佇列 下圖範例 先進先出 後進後出 最先駛入巷道的編號1號的車子會在最前面,最靠近燈號,其次為編號2號的車子 綠燈的時候,首先開出巷道的會是等在最前面的1號車,接著是2號車 先進先出 後進後出

以陣列實作佇列 宣告一個一維整數陣列來存放佇列中的元素 定義兩個變數 “front”和 “rear”,對應到最前面和最後面元 素的註標 定義將資料放入佇列的程序 “put” 定義將資料從佇列取出的程序 “get”

環狀佇列 特色:可以再度回到之前曾被使用過,但是現在已經是空的位置,以有效利用空間 範例資料宣告: 使用運算子 “%”,決定下一個要加入資料的註標位置 利用運算子 “%”,決定將資料取出的註標位置 判斷佇列是空的式子 判斷佇列是滿的式子

圖7-5 環狀佇列示意圖

環狀佇列的相關程序

7-4 樹狀結構 由節點(Node)和邊(Edge)所構成,見圖7-6 節點又可細分為三種: 外部節點(External node):又稱作葉節點,位於樹的最下層,如編號  、  、  等的節點 內部節點(Internal node):不是外部的節點,如編號   、  、  等的節點 根節點(Root node):位於最上層的節點,如編號   的節點 E F H C I G L

L C I K D G H A B J E F 圖7-6 樹的範例

樹的特性 只有唯一一個根節點 樹中沒有迴圈(Loop),也就是任一節點循著邊往下走的話,不可能走回自己 任兩點只有唯一路徑。譬如說,節點  要走到節點  的話,一定會經過節點  ,而沒有其他方法;另一個例子,從節點  要走到節點    的話,也一定會經過節點  和節點   E I G J C K L

樹的相關定義 樹的高度 從根節點到樹中所有葉節點的最長可能路徑 樹的階層 任何一個節點,距離根節點的距離 祖先節點 在某一個節點往上走到根節點的那一條路徑上的所有節點(不包含自己) 父節點為最靠近該節點的祖先節點 祖先節點 在某一個節點往下走到葉節點的所有可能路徑上的所有節點(不包含自己) 子節點為最靠近該節點的子孫節點 子孫節點

二元樹 * * A B c d 每一個節點最多只有二個子節點(可能沒有子節點,或是只有一個) 很常見且具有很多應用 下圖的範例,也稱作運算樹,是將運算子以父節點表示,運算元以子節點表示 * * A B c d 圖7-7 二元樹範例-運算樹

左右子樹 左子樹 右子樹 * * A B c d 左子節點:位於左邊的子節點 左子樹:以該左子節點為根節點所對應的樹 右子節點:位於右邊的子節點 右子樹:以該右子節點為根節點所對應的樹 針對上頁的範例樹,其左右子樹如下圖 左子樹 右子樹 * * A B c d 圖7-8 左子樹和右子樹

實做二元樹 定義樹中每一個節點的資料型態 將左子節點(或左子樹)以指標 “left”表示,而將右子節點 (或右子樹)以指標 “right”表示,示意圖如下: + * * A null B null C null D null 圖7-9 二元樹的實作示意圖

二元樹的三種探訪法 先探訪父節點、再探訪左子節點、最後探訪右子節點 對應到運算式的前序法,如:+*AB*CD 前序法(Preorder) 先探訪父節點、再探訪左子節點、最後探訪右子節點 對應到運算式的前序法,如:+*AB*CD 中序法(Inorder) 先探訪左子節點、再探訪父節點、最後探訪右子節點 對應到運算式的中序法,如:A*B+C*D 後序法(Postorder) 先探訪左子節點、再探訪右子節點、最後探訪父節點 對應到運算式的後序法,如:AB*CD*+

遞迴程序 為二元樹探訪程序的基礎 在程序的本體中,又呼叫到自己本身 遞迴範例: 在此階乘函數中的第二式,我們利用n-1的階乘來計算n的階乘,這就是遞迴的觀念

前序法程序 +*AB*CD 中序法程序 A*B+C*D 後序法程序 AB*CD*+

AB*CD*+ postorder() printf(A) postorder() printf(*) postorder() printf(B) postorder() printf(C) + postorder() printf(*) postorder() printf(D) AB*CD*+