Microsoft PowerPoint - Intro-Comp-Sci-07.ppt [互換モード]

Size: px
Start display at page:

Download "Microsoft PowerPoint - Intro-Comp-Sci-07.ppt [互換モード]"

Transcription

1 情報科学基礎論 年 4 月 4 日情報科学基礎論 3. アルゴリズムとデータ構造 Algorthms ad Data Structures 奥乃 博 data structure( データ構造 ). 配列. リスト 3. 木構造 4. ハッシング Sortg ( 整列 ). 内部整列. 外部整列 ~okuo/lecture/07/itrocs/ 入力 アルゴリズム (Algorthm) アルゴリズム有限回の計算ステップ 停止性 正当性 計算量 (complexty) 時間計算量 空間計算量 出力 O 記法 ( 上限 ) Ω 記法 ( 下限 ) Θ 記法 ( 上下限 ) 3 データ構造 (Data Structure) データの有限集合 しかも 動的に要素の数が変化する集合を扱うための表現 待ち行列 スタック データ構造の抽象化 演算の抽象化 オブジェクトベースド : データ構造と演算のカプセル化 クラスベースド : クラスとインスタンスの区別 オブジェクト指向 : クラス間の階層構造 4 データ構造 : ベクタ (vector) データの並びを表現するデータ型 #( 要素 0 要素 - ) インデックス (dex) は0から始まる (0-org) 要素 は任意のデータ いわゆる 次元配列 (array) Costructor( 構築子 ) (make-vector サイズ [ データ ]) (vector データ 0 データ - ) (lst->vector リスト ) 5 データ構造 : ベクタ (vector)( 続 ) Selectors( 選択子 ) (vector-ref ベクタ インデックス ) その他 (vector-legth ベクタ ) サイズを返す (vector-set! ベクタ インデックス データ ) (vector->lst ベクタ ) 入出力は #( 3 4 5) 6 ベクタ (vector) の例 (defe y (make-vector 5)) #(() () () () ()) (defe x #( 3 4 5)) #( 3 4 5) (vector-legth x) 5 (vector-ref x ) 3 (vector-set! x 3 8) #( 3 8 5) x #( 3 8 5) (vector-set! x 0 'foo) #(foo 3 8 5) 7

2 データ構造 : 配列 (array) N 次元にベクタを拡張 次元の場合 X=[x j ] 3 次元の場合 X=[x j k ] 基本データ構造 待ち行列 ( キュー queue) FIFO(Frst-I Frst-Out) equeue, dequeue スタック (stack) LIFO(Last-I Frst-Out) push, pop 8 データ構造 : リスト (lst) 対 (par) 元セル リスト 並び (sequece) (cos l) (lst ) と同じ l は空リスト (lst 3 4) ドット記法 (dotted otato) (cos ) (cos l) (. ) 箱ポインタ記法 (box-ad-poter otato) t ) (cos (cos (cos 3(cos 4 l) ))) (. l) または () 3 4 ( 3 4) あるいは (. (. (3. (4. l)))) 9 前置記法 (prefx otato) 木の辿り方から 3 つの記法への変換 式 ( 演算子被演算子 ) operator operads 式の記法 前置記法 (prefx otato, Pollsh otato, ポーランド記法 ) +3*45 中置記法 (fx otato) (4 * 5) 後置記法 (postfx otato, reverse Pollsh otato 逆ポーランド記法) * + 木表現はどれも同じ 木の辿り方 前順走査 (pre-order traversal) ノード 左部分木 右部分木 + 3 * 4 5 間順走査 (-order tr.) 左部分木 ノード 右部分木 * 5 後順走査 (post-order tr.) 左部分木 右部分木 ノード * データ構造 : 木 (tree) 木 節 節点 (ode) 頂点(vertex ) 枝 (edge, brach) 辺(arc) 根付き木 (rooted tree) 根 (root) 節 葉(leaf) 節の深さ (depth): 根からその節までの節数 木の高さ (heght): その木に含まれる最大の節の深さ データ構造 : 木 (tree) ( 続 ) 有向木 (drected tree) 親 (paret) 子(chld) 兄弟(sblg) 祖先 (acestor) 子孫(decedet) 順序木 (ordered tree) 根付き木 (rooted tree) かつ 子 ( 兄弟 ) に順序付け 3

3 4 月 4 日 本日のメニュー data structure( データ構造 ). 配列. リスト 3. 木構造 4. ハッシング Sortg ( 整列 ). 内部整列. 外部整列 4 Sortg ( 整列 ) 内部整列 (teral sortg) データはすべて主記憶上に置いて整列. 作業領域を極力減らす. 比較回数を極力減らす 外部整列 (exteral sortg) 外部の記憶装置を用いて整列 3. 主記憶と補助記憶との間でのデータ転送回数を極力減らす 5 Iteral Sortg( 内部整列 ) 逐次入力型. 挿入ソート (serto sort). ヒープソート (heap sort) バッチ型. クイックソート (quck sort). バブルソート (bubble sort) その他 ( 外部整列と共通 ). マージソート (merge sort) 6 安定整列 (stable sortg) 同じデータ間のもともとの順序が整列後も保存されている整列のこと 基数ソート (radx sort) では重要な性質 辞書式順序で整列で基数ソートが使われる 7 挿入ソート (sert sort). データを前から見て行き 適切な場所に入れる. すべてのデータに対して繰り返す 例 : 挿入ソート (sert sort) (defe (sert-sort-pred pred records) (f (ull? records) '() (sert-elem pred (car records) (sert-sort-pred pred (cdr records)) ))) (defe (sert-elem pred elem ordered-rec) (cod ((ull? ordered-rec) rec) (cos elem '())) ((pred elem (car ordered-rec)) (cos elem ordered-rec) ) (else (cos (car ordered-rec) (sert-elem pred elem (cdr orderd-rec) ))))) (defe (sert-sort records. args) (sert-sort-pred (f (ull? args) > (car args))) records )) 9 3

4 挿入ソート (sert sort) の実行トレース (sert-sort-pred > '( 3 6 4)) 挿入ソート (sert sort) の計算量. 最悪の場合 (worst case) (predが とする) 大きなものから順に入ってくる 比較回数は ( ) = ( ) = O( ). 最良の場合 (best case) ) 小さいものから順に入ってくる 比較回数は = ( ) O() = 3. 平均の場合 (average case) すでに入っているデータの半分だけ比較 比較回数は ( ) = ( ) O( = 4 ) 4 クイックソート (quck sort). データが 個ならば整列終了. データの中からpvot( 枢軸 ) を選ぶ 3. 残りのデータのpvotでそれより大きいグループと小さいグループに分割 4. それぞれのグループについて整列 5. 大きいグループの整列結果 pvot 小さいグループの整列結果を順に並べる 例 : クイックソート (quck sort) (defe (quck-sort records. args) (quck-sort-pred (f (ull? args) > (car args)) records )) (defe (quck-sort-pred pred records) (f (ull? records) '() (let* ((pvot (car records)) (dvso (partto pred pvot (cdr records) () () ))) (apped (quck-sort-pred pred (car dvso)) (cos pvot (quck-sort-pred pred (cdr dvso) )))))) (defe (partto pred pvot records left rght) (cod ((ull? records) (cos left rght)) ((pred pvot (car records)) (partto pred pvot (cdr records) left (cos (car records) rght) )) (else (partto pred pvot (cdr records) (cos (car records) left) rght )))) 6 quck sort の実行トレース ( まとめ ) (quck-sort-pred > '( 3 6 4)) (3 6 4) () 3 (6 4) () () () 6 () (4) 4 () () 分割統治法 (dvde ad coquor) 7 クイックソート (quck sort) の計算量. 最悪の場合 (worst case) (predが とする) 小さいものから順に入ってくる parttoでの走査回数は = ( ) = ( + ) = ( ). 最良の場合 (best case) 分割がバランスしている partto の呼ばれる回数は 3. 平均の場合 (average case) O( ) log O( log ) 30 4

5 クイックソート (quck sort) の計算量 3. 平均の場合 (average case) データはすべて異なる あらゆる順列が等確率 途中での分割でも同様の仮定が成立するとする 要素のquck sort に要する時間 : T() とする 左右の結果の統合に要する時間 : c (c: 定数 ) 要素が 要素と-- 要素に分割されたとすると T() T()+T(--)+c T ( ) T ( ) + T ( ) + c 3 クイックソート (quck sort) の計算量 要素の分割 (0,-), (, -),, (-,0) が等確率で生ずるとすると 次の漸化式を得る ( ) = + T c = T () = 0 T (0) = 0 帰納法で証明すると T ( ) ( ) T ( ) log O( log ) 3 クイックソートの補足 pvot のとり方は工夫が必要 すでに並んでいる場合には 最小あるいは最大要素を pvot に取ると最悪 適切な pvot を取れば O( log ) リスト使用の場合は pvot 選択がリスト辿りが必要 コストが重い ベクタ使用の場合には コストが軽い ピープ (heap) というデータ構造 ヒープとは 分木の特殊形 ヒープの高さをhとすると. 高さh- までは完全 分木. 高さh の葉は左詰 3. 親ノードの値 v p と子ノードの値 v c とすると v p pred v c が成立 pred は比較 ベクタで実現する h h ピープ (heap) のベクタ表現 ヒープの高さを h とすると 高さ h- までは完全 分木 高さ h の葉は左詰 ベクタで実現する サイズ0 親のインデックスを 子のインデックスは, h h- 39 ピープの諸演算 手続き (defe (make-heap maxsze) (let ((heap (make-vector (+ maxsze )))) (vector-set! heap 0 0) heap ))) (defe (heap-sze heap) (vector-ref heap 0)) (defe (heap-left-chld ) (* )) (defe (heap-rght-chld ) (+ (* ) )) (defe (heap-paret ) (quotet )) (defe (heap-top heap) (vector-ref heap )) (defe (heap-sze-set! heap ) (vector-set! heap 0 ) ) 0サ + イズ40 5

6 sert-heap ( ピープに要素挿入 ) (defe (sert-heap heap elemet pred) (let (( (+ (heap-sze heap) ))) (vector-set! heap elemet) (heap-sze-set! heap ) (sft-up heap elemet pred) elemet )) sft-up では 高さが つずつ減少 4 sft-up(heap 修復 ) (defe (sft-up heap from elemet pred) (f (<= from ) elemet (let ((paret (heap-paret from))) (let ((value (vector-ref heap paret))) (cod ((pred value elemet) elemet) (else (vector-set! heap from value) (vector-set! heap paret elemet) (sft-up heap paret elemet pred ))))))) 回繰り返すと高さが 減少 要素数を とすると計算量は O(log ) 4 最大要素の抽出と heap 修復 (defe (heap-extract-top heap pred) (let* ((value (heap-top heap)) ( (heap-sze heap)) (elemet (vector-ref heap )) ) (heap-sze-set! heap (- )) (vector-set! heap elemet) (sft-dow heap (- ) elemet pred) value )) sft-dow では 高さが つずつ増加 43 sft-dow(heap 修復 ) (defe (sft-dow heap from to elemet pred) (let ((left-chld (heap-left-chld from)) (rght-chld (heap-rght-chld from)) ) (f (or (>= from to) (> left-chld to)) elemet (let ((max-chld (f (> rght-chld to) left-chld (f (pred (vector-ref heap left-chld) (vector-ref heap rght-chld) ) left-chld rght-chld )))) (let ((max-chld-value (vector-ref heap max-chld))) (cod ((pred elemet max-chld-value) elemet) (else (vector-set! heap from max-chld-value) (vector-set! heap max-chld elemet) (sft-dow heap max-chld to elemet pred )))))))) 44 ヒープソート (heap-sort) (defe (heap-sort records. args) (let ((pred (f (ull? args) >= (car args))) (heap (make-heap 00)) (result ()) ) (for-each (lambda () (sert-heap heap pred)) records) (do (( (legth records) (- )) (result l) ) ((<= 0) (reverse result)) (set! result (cos (heap-extract-top heap pred) result ))))) ヒープソートの計算量 O( log ) 46 ヒープソート (heap-sort) の正しさ ベクタ x のヒープ成立条件 heap(m,) m +, x x [ ] [ ] [] sft-dow では 実行前 : heap(,) の成立は? 実行後 : heap(,3) が成立 回目の sft-dow では 実行前 :heap(,k) は成立, heap(k,)? 実行後 :heap(k,k+) が成立 つまり, heap(,k+) が成立 47 6

7 ヒープソート (heap-sort) の正しさ () ベクタ x のヒープ成立条件 heap(m,) m +, x x [ ] [ ] [] sft-up では 実行前 :heap(,) h ) 成立, heap((+)/,+) だけが? 実行後 :heap((+)/4,(+)/) は? 回目の sft-up では 実行前 :heap(k/,k)? 他は成立 実行後 :heap(k/,) 成立, heap(k/4,k/)? 48 バブルソート (bubble sort) (defe (bubble-sort records. args) (let ((pred (f (ull? args) >= (car args))) (sze (vector-legth records)) ) (do (( 0 (+ ))) ((>= sze) records) (do ((j (- sze ) (- j )) (data l) ) ((<= j )) (set! data (vector-ref records j)) (cod ((pred data (vector-ref records (- j )) ) (vector-set! records j (vector-ref records (- j )) ) (vector-set! records (- j ) data) )))))) 50 バブルソート (bubble sort) 実行トレース バブルソート (bubble sort) の計算量 回ごとに敷居 ( ) が つずつ減る == ( ) = ( ) O( ) 5 シェルソート (Shell sort) バブルソート : 隣接データを比較 h= 飛び飛び (h) に比較 h k = 3h k- +,, の時 e.g., 40, 3, 4, O(.5 ) 53 マージソート ( 併合ソート merge sort) ソート済みのデータを前からマージ ( 併合 ) リスト版 ベクタ版 計算量は両方のデータのスキャンのみ m 個のデータと 個のデータとすると O ( m + ) 空間計算量も余分に O ( m + ) 54 7

8 内部マージソート (I-place merge sort) 分割統治型 内部マージソート (I-place merge sort) 分割統治型 ( ベクタの場合 ) ラン (ru) と言う O( log )55 O( log ) 56 Sortg( 整列 ) のまとめ 選択ソート (selecto sort) 挿入ソート (serto sort) シェルソート (Shell sort) h k = 3h k- +,, の時 k k O( ) O( ) O( 定数小.5 クイックソート (quck sort), 分割統治法 (devde ad coquer) 平均 O ( log ) 最悪 O( ) ヒープソート (heap sort) 常時 O( log ) マージソート (merge sort) 常時 O( log ) ) 57 Sortg( 整列 ) のデモ Java のデモプログラム ~okuo/lecture/07/itroalgds/ 58 Sort( 整列 ) 済ベクタの探索 分探索 (bary search) > = < 比較 > = < > = < 分探索の計算量 O(log ) 60 4 月 4 日 本日のメニュー Sortg ( 整列 ). 内部整列. 外部整列 data structure( データ構造 ). 配列. リスト 3. 木構造 4. ハッシング 63 8

9 ハッシュ法 (hashg) 探したいデータの範囲膨大 例 : 最大 0 文字の単語 50 文字とすると組合わせの数は 0 log(50 ) 0( log ) = 7 ところが実際の単語数は高々 6 0 ベクタ ( 配列 ) で単語を管理すると疎すかすかの配列 ハッシュ法 (hasg) を使用 0 64 辞書とハッシュ表 apocope 語尾消失 ッapocalypse 黙示シュ値エントリハハッシュ apocrypha 聖書外典 apocalypse apogee 遠地点 apodoss 帰結節 apogee 遠地点 drectaccess table apocope 6 apocrypha 4 apodoss 5 apogee 0 ( 空 ) apocalypse apocrypha apodoss apocope 65 ハッシュ法 (hashg) キーの値の探索なしにアクセス ハッシュ関数 (hash fucto) キー ハッシュ値 ( 整数 ) ハッシュ表 (hash table) ) サイズ M 占有率 (load factor)α データ量 N α = N M 異なるキーに対してハッシュ値が同じハッシュ値の衝突 (collso) 67 ハッシュ関数 (hash fucto) 設計の指針 : ランダム性を有するもの キー : x = a a L key ( x) = m 例 : キーから h ( x) m mod M 例 : 文字列から整数への写像 = h ( x) a code( a ) mod M 例 3: m の中央部分の logm 桁分を使用 h3 ( x) m mod M K where costat K such that MK N 68 ハッシュ法の基本手続き 挿入 (sert) hash 表に key を持つデータを挿入 検索 (member) hash 表からkeyでデータを検索 削除 (delete) hash 表から key を持つデータを削除 ハッシュ値衝突 (collso) 対処法 チェイン法 (chag, separate chag, 連鎖法 内部ハッシュ法 ) 開番地法 (ope addressg, オープン法 外部ハッシュ法 ). 線形走査法 (lear probg). 万能ハッシュ法 (uversal hashg) 3. 重ハッシュ法 (double hashg) h, gとすると h(x), h(x)+g(x), h(x)+g(x), h(x)+3g(x),

10 dog curb brd チェイン法 brd ハッシュ値の衝突 Backet( バケツ ) を作り つないで行く チェイン法の平均最悪計算量. 挿入 Θ(N). 検索 Θ(N) 3. 削除 Θ(N) 7 内部ハッシュ法 (teral hashg) ハッシュ関数 h α = 占有率 α エントリに状態を導入 N M < /deleted/key( データ ). 挿入 : /deleted というフラグのあるエントリに入れる. 検索 : /deletedまで探す 3. 削除 : deletedというフラグを立てる deleted キー データ キー データ 7 線形走査法 (lear probg) ハッシュ関数 h 衝突発生時 h h+ mod M 挿入 /deleted というフラグのあるエントリに入れる 検索 /deletedまで探す 削除 deletedというフラグを立てる 73 万能ハッシュ法 (uversal hashg) ハッシュ関数 h, ハッシュ関数をランダムに選択 挿入 /deleted というフラグのあるエントリに入れる 検索 /deletedまで探す 削除 deletedというフラグを立てる 74 重ハッシュ法 (double hashg) ハッシュ関数 h, g 衝突発生時 h h+g mod M 挿入 /deleted というフラグのあるエントリに入れる 検索 /deletedまで探す 削除 deletedというフラグを立てる 75 線形走査法 (lear probg) の例. h(dog)=. h(kyoto)=4 3. h(uv)=0 4. h(iformatcs)= 5. h(sicp)=3 6. h(test)=

11 線形走査法の挿入の計算量. 個のデータが格納 + 個目のデータを挿入するときにh (x) が 回目で空いている確率 + L M M M M +. 空きセルを見つけるまでの比較回数 M ( ) L( + ) M + + = = M ( M ) L( M + ) = M M 3. ハッシュ表にN 個のデータを挿入する手間は N M N M dx = M log M x e 0 = 0 M M N M 77 線形走査法の挿入の計算量 ( 続 ) 4. 回あたりの平均の挿入の手間は M M loge loge( α) N M N + α Computatoal Complexty /(-α) -/α log (-α) Load Factor load factor α α loge( α) α 78 線形走査法の検索の計算量. deleted はないものと仮定. 表にキーがない時は =N の挿入と同じ M = M N α 3. 表にキーがある時 M M loge loge( α) N M N + α 4. 削除も検索と同じ 5. 上記の解析は 一様ハッシュ (uform hashg) を仮定 : キーの探索列ランダム 79 線形走査法の削除の計算量. deleted はないものと仮定. 表にキーがない時は =N の挿入と同じ 3. 表にキーがある時 M = M N α M M loge loge( α) N M N + α 8 ハッシュ表というデータ構造 (defe (quck-sort records. args) (quck-sort-pred (f (ull? args) > (car args)) records )) (defe (quck-sort-pred pred records) (f (ull? records) l (let* ((pvot (car records)) (dvso (partto pred pvot (cdr records) l l)) ) (apped (quck-sort-pred pred (car dvso)) (cos pvot (quck-sort-pred pred (cdr dvso)) ))))) (defe (partto pred pvot records left rght) (cod ((ull? records) (cos left rght)) ((pred pvot (car records)) (partto pred pvot (cdr records) left (cos (car records) rght) )) (else (partto pred pvot (cdr records) (cos (car records) left) rght )))) (defe (sert-sort records. args) (sert-sort-pred (f (ull? args) > (car args))) records )) 8 レポート課題 : 5 月 日午後 5 時締切 どれか つアルゴリズムを選び 次の課題を行え. アルゴリズムを説明せよ 今日習ったアルゴリズム ご自身の研究に関係するアルゴリズム. アルゴリズムの挙動を表示 ( 可視化 ) するプログラムを作成せよ MATLAB Java などで レポートとプログラムはメイルで提出のこと okuo@.kyoto-u.ac.jp 83

Microsoft PowerPoint - IntroAlgDs ppt

Microsoft PowerPoint - IntroAlgDs ppt アルゴリズムとデータ構造入門 -4 006 年 月 7 日 アルゴリズムとデータ構造入門 Sorting( 整列 ) Hashing( ハッシュ法 ) 奥乃 博 年前の今朝阪神 淡路大震災犠牲者死者だけで 6434 人天災は忘れた頃にやってくる ( 寺田寅彦 ) 天才は忘れた頃にやってくる ( 奥乃博 ) 月 7 日 本日のメニュー. vector ( ベクタ ). Sorting ( 整列 ) 3.

More information

Microsoft PowerPoint - IntroAlgDs ppt [互換モード]

Microsoft PowerPoint - IntroAlgDs ppt [互換モード] アルゴリズムとデータ構造入門 -4 008 年 月 5 日 アルゴリズムとデータ構造入門 Sorting( 整列 ) Hashing( ハッシュ法 ) 奥乃博祝成人の日 年前の7 日阪神 淡路大震災犠牲者死者だけで6434 人天災は忘れた頃にやってくる ( 寺田寅彦 ) 天才は忘れた頃にやってくる ( 奥乃博 ) (Asahi.com より転載 ) 月 5 日 本日のメニュー. vector ( ベクタ

More information

Microsoft PowerPoint - IntroAlgDs pptx

Microsoft PowerPoint - IntroAlgDs pptx アルゴリズムとデータ構造入門 -3 04 年 月 4 日 大学院情報学研究科知能情報学専攻 http://wiie.kuis.kyoto-u.ac.jp/~okuo/lecture//itroalgds/ okuo@i.kyoto-u.ac.jp,okuo@ue.org if mod( 学籍番号の下 3 桁,3) 0 if mod( 学籍番号の下 3 桁,3) if mod( 学籍番号の下 3 桁,3).

More information

Microsoft PowerPoint - IntroAlgDs pptx

Microsoft PowerPoint - IntroAlgDs pptx アルゴリズムとデータ構造入門 -14 2012 年 1 月 8 日 大学院情報学研究科知能情報学専攻 http://winnie.kuis.kyoto-u.ac.jp/~okuno/lecture/11/introalgds/ okuno@i.kyoto-u.ac.jp,okuno@nue.org if mod( 学籍番号の下 3 桁,3) 0 if mod( 学籍番号の下 3 桁,3) 1 if

More information

Microsoft PowerPoint - IntroAlgDs pptx

Microsoft PowerPoint - IntroAlgDs pptx アルゴリズムとデータ構造入門 -14 2014 年 1 月 21 日 大学院情報学研究科知能情報学専攻 http://winni.kuis.kyoto-u.ac.jp/~okuno/lctur/13/introalgds/ okuno@i.kyoto-u.ac.jp,okuno@nu.org if mod( 学籍番号の下 3 桁,3) 0 if mod( 学籍番号の下 3 桁,3) 1 if mod(

More information

PowerPoint Presentation

PowerPoint Presentation 算法数理工学 第 2 回 定兼邦彦 クイックソート n 個の数に対して最悪実行時間 (n 2 ) のソーティングアルゴリズム 平均実行時間は (n log n) 記法に隠された定数も小さい in-place ( 一時的な配列が必要ない ) 2 クイックソートの記述 分割統治法に基づく 部分配列 A[p..r] のソーティング. 部分問題への分割 : 配列 A[p..r] を 2 つの部分配列 A[p..q]

More information

Microsoft PowerPoint - algo ppt [互換モード]

Microsoft PowerPoint - algo ppt [互換モード] ( 復習 ) アルゴリズムとは アルゴリズム概論 - 探索 () - アルゴリズム 問題を解くための曖昧さのない手順 与えられた問題を解くための機械的操作からなる有限の手続き 機械的操作 : 単純な演算, 代入, 比較など 安本慶一 yasumoto[at]is.naist.jp プログラムとの違い プログラムはアルゴリズムをプログラミング言語で表現したもの アルゴリズムは自然言語でも, プログラミング言語でも表現できる

More information

PowerPoint Presentation

PowerPoint Presentation 算法数理工学 第 回 定兼邦彦 クイックソートの 確率的アルゴリズム クイックソートの平均的な場合の実行時間を解析する場合, 入力の頻度を仮定する必要がある. 通常は, すべての順列が等確率で現れると仮定 しかし実際にはこの仮定は必ずしも期待できない この仮定が成り立たなくてもうまく動作するクイックソートの確率的アルゴリズムを示す 確率的 radomized) アルゴリズム 動作が入力だけでなく乱数発生器

More information

Microsoft Word - 13

Microsoft Word - 13 担当 : 富井尚志 (tommy@ynu.ac.jp) アルゴリズムとデータ構造 講義日程 1. 基本的データ型 2. 基本的制御構造 3. 変数のスコープルール. 関数 4. 配列を扱うアルゴリズムの基礎 (1). 最大値, 最小値 5. 配列を扱うアルゴリズムの基礎 (2). 重複除去, 集合演算, ポインタ 6. ファイルの扱い 7. 整列 (1). 単純挿入整列 単純選択整列 単純交換整列

More information

Microsoft PowerPoint - kougi10.ppt

Microsoft PowerPoint - kougi10.ppt C プログラミング演習 第 10 回二分探索木 1 例題 1. リストの併合 2 つのリストを併合するプログラムを動かしてみる head1 tail1 head2 tail2 NULL NULL head1 tail1 tail1 があると, リストの併合に便利 NULL 2 #include "stdafx.h" #include struct data_list { int data;

More information

Microsoft PowerPoint - 05.pptx

Microsoft PowerPoint - 05.pptx アルゴリズムとデータ構造第 5 回 : データ構造 (1) 探索問題に対応するデータ構造 担当 : 上原隆平 (uehara) 2015/04/17 アルゴリズムとデータ構造 アルゴリズム : 問題を解く手順を記述 データ構造 : データや計算の途中結果を蓄える形式 計算の効率に大きく影響を与える 例 : 配列 連結リスト スタック キュー 優先順位付きキュー 木構造 今回と次回で探索問題を例に説明

More information

Microsoft PowerPoint - 06.pptx

Microsoft PowerPoint - 06.pptx アルゴリズムとデータ構造第 6 回 : 探索問題に対応するデータ構造 (2) 担当 : 上原隆平 (uehara) 2015/04/22 内容 スタック (stack): 最後に追加されたデータが最初に取り出される 待ち行列 / キュー (queue): 最初に追加されたデータが最初に取り出される ヒープ (heap): 蓄えられたデータのうち小さいものから順に取り出される 配列による実装 連結リストによる実装

More information

Microsoft PowerPoint - IntroAlgDs-05-2.ppt

Microsoft PowerPoint - IntroAlgDs-05-2.ppt アルゴリズムとデータ構造入門 2005 年 10 月 11 日 アルゴリズムとデータ構造入門 1. 手続きによる抽象の構築 1.1 プログラムの要素 奥乃 博 1. TUT Schemeが公開されました. Windowsは動きます. Linux, Cygwin はうまく行かず. 調査中. 2. 随意課題 7の追加 友人の勉学を助け,TAの手伝いをする. 支援した内容を毎回のレポート等で詳細に報告.

More information

memo

memo 計数工学プログラミング演習 ( 第 6 回 ) 2016/05/24 DEPARTMENT OF MATHEMATICAL INFORMATICS 1 今日の内容 : 再帰呼び出し 2 分探索木 深さ優先探索 課題 : 2 分探索木を用いたソート 2 再帰呼び出し 関数が, 自分自身を呼び出すこと (recursive call, recursion) 再帰を使ってアルゴリズムを設計すると, 簡単になることが多い

More information

Microsoft PowerPoint - algo ppt [互換モード]

Microsoft PowerPoint - algo ppt [互換モード] 平衡木 アルゴリズム概論 - 探索 (2)- 安本慶一 yasumoto[at]is.naist.jp 二分探索木 高さがデータを挿入 削除する順番による 挿入 削除は平均 O(log n) だが, 最悪 O(n) 木の高さをできるだけ低く保ちたい 平衡木 (balanced tree) データを更新する際に形を変形して高さが log 2 n 程度に収まるようにした木 木の変形に要する時間を log

More information

alg2015-6r3.ppt

alg2015-6r3.ppt 1 アルゴリズムとデータ 構造 第 6 回探索のためのデータ構造 (1) 補稿 : 木の巡回 ( なぞり ) 2 木の巡回 ( 第 5 回探索 (1) のスライド ) 木の巡回 * (traverse) とは 木のすべての節点を組織だった方法で訪問すること 深さ優先探索 (depth-first search) による木の巡回 *) 木の なぞり ともいう 2 3 1 3 4 1 4 5 7 10

More information

プログラム言語及び演習Ⅲ

プログラム言語及び演習Ⅲ 平成 28 年度後期データ構造とアルゴリズム期末テスト 各問題中のアルゴリズムを表すプログラムは, 変数の宣言が省略されているなど, 完全なものではありませんが, 適宜, 常識的な解釈をしてください. 疑問があれば, 挙手をして質問してください. 時間計算量をオーダ記法で表せという問題では, 入力サイズ n を無限大に近づけた場合の漸近的な時間計算量を表せということだと考えてください. 問題 1 入力サイズが

More information

Microsoft PowerPoint - ad11-09.pptx

Microsoft PowerPoint - ad11-09.pptx 無向グラフと有向グラフ 無向グラフ G=(V, E) 頂点集合 V 頂点の対を表す枝の集合 E e=(u,v) 頂点 u, v は枝 e の端点 f c 0 a 1 e b d 有向グラフ G=(V, E) 頂点集合 V 頂点の順序対を表す枝の集合 E e=(u,v) 頂点 uは枝 eの始点頂点 vは枝 eの終点 f c 0 a 1 e b d グラフのデータ構造 グラフ G=(V, E) を表現するデータ構造

More information

Microsoft PowerPoint - 7.pptx

Microsoft PowerPoint - 7.pptx 7. 木構造 7-1. データ構造としての木 グラフ理論での木の定義 根付き木 7-2.2 分探索木 7-3. 高度な木 ( 平衡木 ) AVL 木 B 木 1 7-1 1. データ構造としての木 2 木構造 木構造を表すデータ構造の一つとしてヒープがある しかし ヒープでは 配列を用いプではるため 要素数で木の形状が一通りに決定してしまった ここでは 再帰的なデータ構造を用いることにより より柔軟な木構造が構築可能なより柔軟な木構造が構築可能なことを見ていく

More information

第2回

第2回 明星大学情報学科 年後期 アルゴリズムとデータ構造 Ⅰ 第 回 Page 第 回基本データ構造 連結リストとその操作 -. リスト構造 データ部 と ポインタ部 で構成され ポインタをたどることによりデータを扱うことができる構造 -. 単方向リストとその操作 --. 単方向リスト 次のデータへのポインタを つだけ持っているデータ構造 ( データ部は 複数のデータを持っている場合もある ) データ部

More information

Microsoft PowerPoint - DA1_2019.pptx

Microsoft PowerPoint - DA1_2019.pptx データ構造とアルゴリズム IB 九州大学大学院システム情報科学研究院情報学部門横尾真 E-mail: yokoo@inf.kyushu-u.ac.jp http://agent.inf.kyushu-u.ac.jp/~yokoo/ 自己紹介 年東京大学大学院工学系研究科電気工学専門課程修士課程修了 同年日本電信電話株式会社 (NTT) 入社 NTT 情報通信処理研究所 ( 神奈川県横須賀市 ), NTT

More information

memo

memo 計数工学プログラミング演習 ( 第 6 回 ) 2017/05/16 DEPARTMENT OF MATHEMATICAL INFORMATICS 1 今日の内容 : 再帰呼び出し 2 分探索木 深さ優先探索 課題 : 2 分探索木を用いたソート 2 再帰呼び出し 関数が, 自分自身を呼び出すこと (recursive call, recursion) 再帰を使ってアルゴリズムを設計すると, 簡単になることが多い

More information

論理と計算(2)

論理と計算(2) 情報科学概論 Ⅰ アルゴリズムと計算量 亀山幸義 http://logic.cs.tsukuba.ac.jp/~kam 亀山担当分の話題 アルゴリズムと計算量 Fibonacci 数列の計算を例にとり アルゴリズムと計算量とは何か 具体的に学ぶ 良いアルゴリズムの設計例として 整列 ( ソーティング ) のアルゴリズムを学ぶ 2 Fibonacci 数 () Fibonacci 数 (2) = if

More information

Microsoft PowerPoint - ca ppt [互換モード]

Microsoft PowerPoint - ca ppt [互換モード] 008//8 大阪電気通信大学情報通信工学部光システム工学科 年次配当科目 コンピュータアルゴリズム 探索アルゴリズム () 第 8 講 : 平成 0 年 月 8 日 ( 金 ) 4 限 E5 教室 中村嘉隆 ( なかむらよしたか ) 奈良先端科学技術大学院大学助教 y-nkmr@is.nist.jp http://nrym.nist.jp/~y-nkmr/ 第 講の復習 探索アルゴリズム 探索するデータ構造

More information

alg2015-4r2.ppt

alg2015-4r2.ppt 1 アルゴリズムとデータ 構造 第 4 回基本的なデータ構造 ( ヒープ ) 再帰的アルゴリズム 2017/04/18 アルゴリズムとデータ構造 2 リスト リストとは要素を 0 個以上 1 列に並べたもの リスト a 0,a 1,,a n-1 の実現法 1. 配列 (array) 前回の復習 (1/3) a 0 a 1 a n-1 2. 連結リスト (linked list) init a 0 a

More information

Microsoft PowerPoint - 06graph3.ppt [互換モード]

Microsoft PowerPoint - 06graph3.ppt [互換モード] I118 グラフとオートマトン理論 Graphs and Automata 担当 : 上原隆平 (Ryuhei UEHARA) uehara@jaist.ac.jp http://www.jaist.ac.jp/~uehara/ 1/20 6.14 グラフにおける探索木 (Search Tree in a Graph) グラフG=(V,E) における探索アルゴリズム : 1. Q:={v { 0 }

More information

自己紹介 ( 専門分野 ) プログラミング言語の研究 特に基礎理論 研究の出発点 : 自分がうまくプログラムが書けないのを言語のせいにする プログラムの間違いを自動発見する仕組みを作る そもそも間違いを犯しにくいプログラミング言語を作る

自己紹介 ( 専門分野 ) プログラミング言語の研究 特に基礎理論 研究の出発点 : 自分がうまくプログラムが書けないのを言語のせいにする プログラムの間違いを自動発見する仕組みを作る そもそも間違いを犯しにくいプログラミング言語を作る 全学共通科目 工学部専門科目 計算機科学概論 アルゴリズムとプログラミングその 1 五十嵐淳 igarashi@kuis.kyoto-u.ac.jp 大学院情報学研究科通信情報システム専攻 自己紹介 ( 専門分野 ) プログラミング言語の研究 特に基礎理論 研究の出発点 : 自分がうまくプログラムが書けないのを言語のせいにする プログラムの間違いを自動発見する仕組みを作る そもそも間違いを犯しにくいプログラミング言語を作る

More information

Microsoft PowerPoint - 13approx.pptx

Microsoft PowerPoint - 13approx.pptx I482F 実践的アルゴリズム特論 13,14 回目 : 近似アルゴリズム 上原隆平 (uehara@jaist.ac.jp) ソートの下界の話 比較に基づく任意のソートアルゴリズムはΩ(n log n) 時間の計算時間が必要である 証明 ( 概略 ) k 回の比較で区別できる場合の数は高々 2 k 種類しかない n 個の要素の異なる並べ方は n! 通りある したがって少なくとも k n 2 n!

More information

Microsoft Word - 中間試験 その1_解答例.doc

Microsoft Word - 中間試験 その1_解答例.doc 問題 1.C 言語 情報技術 Ⅱ 前半中間試験 次の宣言をしている時 以下の問いに答えよ unsigned char moji_1; struct Kouzou { unsigned char code; unsigned char str[10]; }; struct Kouzou mk[3]; 明星大学情報学科 3 年後期 情報技術 Ⅱ 中間試験その 1 Page 1 1-1. 各値を求めよ (1)sizeof(

More information

第2回

第2回 第 4 回基本データ構造 1 明星大学情報学科 2 3 年前期 アルゴリズムとデータ構造 Ⅰ 第 4 回 Page 1 配列 スタック キューとその操作 4-1. 配列とその操作 配列型 同じ型の変数を並べたもの 配列にする型は 基本型 配列型 構造体 ポインタいずれでもよい 要素の並べ方を 次元 という 1 次元配列 ( 直線状 ) 2 次元配列 ( 平面状 ) 3 次元配列 ( 立体状 ) a[5]

More information

Microsoft PowerPoint - 5.pptx

Microsoft PowerPoint - 5.pptx 5. サーチ 5-1. 線形探索 5-2.2 分探索 5-3. ハッシュ 1 サーチ問題 入力 :n 個のデータ a, a,, an a n 0 1 1 ( ここで 入力サイズは とします ) さらに キー k 出力 : k = a となる a があるときは i i となるがあるときは その位置 i,(0 i n 1) キーが存在しないとき -1 2 探索 ( サーチ ) 入力 : 5 3 8 1

More information

始めに, 最下位共通先祖を求めるための関数 LcaDFS( int v ) の処理を記述する. この関数は値を返さない再帰的な void 関数で, 点 v を根とする木 T の部分木を深さ優先探索する. 整数の引数 v は, 木 T の点を示す点番号で, 配列 NodeSpace[ ] へのカーソル

始めに, 最下位共通先祖を求めるための関数 LcaDFS( int v ) の処理を記述する. この関数は値を返さない再帰的な void 関数で, 点 v を根とする木 T の部分木を深さ優先探索する. 整数の引数 v は, 木 T の点を示す点番号で, 配列 NodeSpace[ ] へのカーソル 概略設計書 作成者築山修治作成日 2012 年 10 月 1 日 概要 ( どのような入力に対して, どのような出力をするかの概要説明 ) * 木 T および質問点対の集合 P が与えられたとき, 各質問点対 p = (v,w) P の最下位共通先祖 ( すなわち木 T において点 v と w の共通の先祖 a で,a の真の子孫には v と w の共通の先祖が無いような点 ) を見出す関数である.

More information

PowerPoint Presentation

PowerPoint Presentation 今週のトピックス アルゴリズムとデータ構造 第 10 回講義 : 探索その 1 探索 (search) 逐次探索 (sequential search) 2 分探索 (binary search) 内挿探索 (interpolation search) Produced by Qiangfu Zhao (Since 2009), All rights reserved (c) 1 Produced

More information

次に示す数値の並びを昇順にソートするものとする このソートでは配列の末尾側から操作を行っていく まず 末尾の数値 9 と 8 に着目する 昇順にソートするので この値を交換すると以下の数値の並びになる 次に末尾側から 2 番目と 3 番目の 1

次に示す数値の並びを昇順にソートするものとする このソートでは配列の末尾側から操作を行っていく まず 末尾の数値 9 と 8 に着目する 昇順にソートするので この値を交換すると以下の数値の並びになる 次に末尾側から 2 番目と 3 番目の 1 4. ソート ( 教科書 p.205-p.273) 整列すなわちソートは アプリケーションを作成する際には良く使われる基本的な操作であり 今までに数多くのソートのアルゴリズムが考えられてきた 今回はこれらソートのアルゴリズムについて学習していく ソートとはソートとは与えられたデータの集合をキーとなる項目の値の大小関係に基づき 一定の順序で並べ替える操作である ソートには図 1 に示すように キーの値の小さいデータを先頭に並べる

More information

論理と計算(2)

論理と計算(2) 情報科学概論 Ⅰ アルゴリズムと計算 亀山幸義 http://logic.cs.tsukuba.ac.jp/~kam 計算とは? コンピュータが計算できることは? 1 2 関数 = 計算? NO 部分関数と計算 入力 1 入力 2 関数 出力 入力 1 入力 2 部分関数 出力 停止しない 入力 1 入力 2 コンピュータ 止まらないことがある出力 3 入力 1 入力 2 コンピュータ 出力 停止しない

More information

PG13-6S

PG13-6S プログラム演習 I レポート 学籍番号 担当教員 : 小林郁夫 氏名 実習日平成 26 年 7 月 4 日 提出期限 7 月 11 日提出日 7 月 17 日 1 週遅れ 第 13 回 テーマ : 並べ替えのアルゴリズム 教員使用欄 15 S A B C 再提出 課題 1 バブルソートの実行画面 プログラムのソースコード // day13_akb1.cpp : コンソールアプリケーションのエントリポイントを定義します

More information

Microsoft Word - 12

Microsoft Word - 12 担当 : 富井尚志 (tommy@ynu.ac.jp) アルゴリズムとデータ構造 講義日程. 基本的データ型. 基本的制御構造. 変数のスコープルール. 関数. 配列を扱うアルゴリズムの基礎 (). 最大値, 最小値. 配列を扱うアルゴリズムの基礎 (). 重複除去, 集合演算, ポインタ. ファイルの扱い 7. 整列 (). 単純挿入整列 単純選択整列 単純交換整列 8. 整列 (). マージ整列

More information

Microsoft PowerPoint - DA1_2018.pptx

Microsoft PowerPoint - DA1_2018.pptx データ構造とアルゴリズム IB 九州大学大学院システム情報科学研究院情報学部門横尾真 E-mail: yokoo@inf.kyushu-u.ac.jp http://agent.inf.kyushu-u.ac.jp/~yokoo/ 自己紹介 年東京大学大学院工学系研究科電気工学専門課程修士課程修了 同年日本電信電話株式会社 (NTT) 入社 NTT 情報通信処理研究所 ( 神奈川県横須賀市 ), NTT

More information

Microsoft PowerPoint - ca ppt [互換モード]

Microsoft PowerPoint - ca ppt [互換モード] 大阪電気通信大学情報通信工学部光システム工学科 年次配当科目 コンピュータアルゴリズム 探索アルゴリズム (1) 第 講 : 平成 0 年 11 月 1 日 ( 金 ) 4 限 E 教室 中村嘉隆 ( なかむらよしたか ) 奈良先端科学技術大学院大学助教 y-nakamr@is.naist.jp http://narayama.naist.jp/~y-nakamr/ 第 4 講の復習 整列アルゴリズム

More information

データ構造と  アルゴリズムⅠ

データ構造と  アルゴリズムⅠ 算法数理工学 第 5 回 定兼邦彦 ハッシュ表 辞書操作 (INSERT, DELETE, SEARCH) を効率よく実現するデータ構造 応用 :C 言語のコンパイラでの記号表の管理 キー : 変数名などの文字列 ハッシュ表は実際的な場面では極めて速い 妥当な仮定の下で,SEARCH の時間の期待値は O() 最悪の場合 () 2 チェイン法を用いるハッシュ法の解析 SEARCH は最悪の場合 ()

More information

memo

memo 計数工学プログラミング演習 ( 第 5 回 ) 2017/05/09 DEPARTMENT OF MATHEMATICAL INFORMATICS 1 内容 文字列 双方向リスト ハッシュ 2 文字列 文字列は char の配列 char name[] = ABC ; name は ABC を格納するのに十分な長さの配列 長さは, 文字列の長さ + 1 ( 終端記号用 ) char name[4]

More information

データ構造

データ構造 アルゴリズム及び実習 7 馬青 1 表探索 定義表探索とは 表の形で格納されているデータの中から条件に合ったデータを取り出してくる操作である 但し 表は配列 ( 連結 ) リストなどで実現できるので 以降 表 の代わりに直接 配列 や リスト などの表現を用いる場合が多い 表探索をただ 探索 と呼ぶ場合が多い 用語レコード : 表の中にある個々のデータをレコード (record) と呼ぶ フィールド

More information

5after探索( )

5after探索( ) 探索アルゴリズム 探索とは? キー 一致するものを探す レコード フィールド START n=10, i =0, target=54 i : n a[i] : target i++ < = 線形探索アルゴリズム (1) 前提 : 配列 a に n 個のデータが保存 処理 :target と同じデータが蓄えられている配列要素の添え字を返し, ない場合は -1 を返すフローチャートを記せ return

More information

Microsoft PowerPoint - 11.pptx

Microsoft PowerPoint - 11.pptx ポインタと配列 ポインタと配列 配列を関数に渡す 法 課題 : 配列によるスタックの実現 ポインタと配列 (1/2) a が配列であるとき, 変数の場合と同様に, &a[0] [] の値は配列要素 a[0] のアドレス. C 言語では, 配列は主記憶上の連続領域に割り当てられるようになっていて, 配列名 a はその配列に割り当てられた領域の先頭番地となる. したがって,&a[0] と a は同じ値.

More information

第 3 回 Java 講座 今回の内容 今週の Java 講座はコレクション 拡張 for 文, ガベージコレクションについて扱う. 今週の Java 講座は一番内容が薄いも のになるだろう. コレクション コレクションとは大きさが決まっていない配列だと考えればよい. コレクションには List 先

第 3 回 Java 講座 今回の内容 今週の Java 講座はコレクション 拡張 for 文, ガベージコレクションについて扱う. 今週の Java 講座は一番内容が薄いも のになるだろう. コレクション コレクションとは大きさが決まっていない配列だと考えればよい. コレクションには List 先 第 3 回 Java 講座 今回の内容 今週の Java 講座はコレクション 拡張 for 文, ガベージコレクションについて扱う. 今週の Java 講座は一番内容が薄いも のになるだろう. コレクション コレクションとは大きさが決まっていない配列だと考えればよい. コレクションには List 先頭の要素要素から最後までが直線的に直結している構造 Set 同じものは含まないという構造. 要素間につながりはない

More information

memo

memo 計数工学プログラミング演習 ( 第 4 回 ) 2016/05/10 DEPARTMENT OF MATHEMATICA INFORMATICS 1 内容 リスト 疎行列 2 連結リスト (inked ists) オブジェクトをある線形順序に並べて格納するデータ構造 単方向連結リスト (signly linked list) の要素 x キーフィールド key ポインタフィールド next x->next:

More information

情報処理Ⅰ

情報処理Ⅰ Java フローチャート -1- フローチャート ( 流れ図 ) プログラムの処理手順 ( アルゴリズム ) を図示したもの 記号の種類は下記のとおり 端子記号 ( 開始 終了 ) 処理記号計算, 代入等 条件の判定 条件 No ループ処理 LOOP start Yes データの入力 出力 print など 定義済み処理処理名 end サンプルグログラム ( 大文字 小文字変換 ) 大文字を入力して下さい

More information

Microsoft PowerPoint - 6.pptx

Microsoft PowerPoint - 6.pptx 6. データ構造入門 6-1. 連結リスト (Linked List) 6-2. スタック (Stack) 6-. キュー (Queue) 6-4. デク (Double-Ended-Queue) 6-. 抽象データ型 (Abstract Data Type) データ構造とは データの保存を効率的に行うもの 1 ito 2.712.14 suzuki データ構造 1 2 6-1. 連結リスト (Linked

More information

alg2015-3r3.ppt

alg2015-3r3.ppt 1 アルゴリズムとデータ 構造 第 3 回基本的なデータ構造 ( リスト スタック キュー ) プログラミング で学ぶところ 授業で学ぶデータ構造の範囲 機械語のデータ型 レジスタ値とその番地 基本データ型 char, int, large int, double, 構造データ型 配列 (array), 構造体 (struct) 基本的データ構造 リスト (linked list), スタック (stack),

More information

簡単な検索と整列(ソート)

簡単な検索と整列(ソート) フローチャート (2) アルゴリズム論第 2 回講義 2011 年 10 月 7 日 ( 金 ) 反復構造 ( 一定回数のループ処理 ) START 100 回同じ処理を繰り返す お風呂で子供が指をおって数を数える感じ 繰り返し数を記憶する変数をカウンター ( 変数名 I をよく使う ) と呼ぶ カウンターを初期化して, 100 回繰り返したかどうか判定してそうならば終了そうでなければ処理を実行して

More information

Microsoft PowerPoint - lecture02.pptx

Microsoft PowerPoint - lecture02.pptx アルゴリズム論 ( 第 10 回 ) マージソート 佐々木研 ( 情報システム構築学講座 ) 講師山田敬三 k-yamada@iwate-pu.ac.jp 内部ソートと外部ソート 内部ソート メモリを使用 外部ソート ファイルを直接操作してソートを行う. 一般に, 主記憶 < 補助記憶 外部ソートの留意点 1. 記憶空間を節約することは考慮しない. ソートを高速化するためには, 同じデータをいくつかのファイルに同時に格納

More information

Microsoft PowerPoint - exp2-02_intro.ppt [互換モード]

Microsoft PowerPoint - exp2-02_intro.ppt [互換モード] 情報工学実験 II 実験 2 アルゴリズム ( リスト構造とハッシュ ) 実験を始める前に... C 言語を復習しよう 0. プログラム書ける? 1. アドレスとポインタ 2. 構造体 3. 構造体とポインタ 0. プログラム書ける? 講義を聴いているだけで OK? 言語の要素技術を覚えれば OK? 目的のプログラム? 要素技術 データ型 配列 文字列 関数 オブジェクト クラス ポインタ 2 0.

More information

memo

memo 数理情報工学演習第一 C ( 第 8 回 ) 206/06/3 DEPARTMENT OF MATHEMATICAL INFORMATICS 今日の内容 : プロトタイプ宣言 ヘッダーファイル, プログラムの分割 プライオリティキュー ヒープ 課題 : ヒープソート 2 プロトタイプ宣言 C 言語では, 関数や変数は使用する前 ( ソースの上のほう ) に定義されている必要がある. double sub(int

More information

COMPUTING THE LARGEST EMPTY RECTANGLE

COMPUTING THE LARGEST EMPTY RECTANGLE COMPUTING THE LARGEST EMPTY RECTANGLE B.Chazelle, R.L.Drysdale and D.T.Lee SIAM J. COMPUT Vol.15 No.1, February 1986 2012.7.12 TCS 講究関根渓 ( 情報知識ネットワーク研究室 M1) Empty rectangle 内部に N 個の点を含む領域長方形 (bounding

More information

離散数学

離散数学 離散数学 グラフ探索アルゴリズム 落合秀也 今日の内容 グラフの連結性 の判定 幅優先探索 幅優先探索の実現方法 深さ優先探索 深さ優先探索の実現方法 木の構造 探索木 パトリシア トライ 2 連結性の判定問題を考える グラフ G(V,E) が与えられたとき G が連結かどうか を判定したい 小さいグラフなら 紙に書いてみればよい 一般には簡単ではない 大きいグラフの場合 コンピュータに判断させる場合

More information

Taro-再帰関数Ⅲ(公開版).jtd

Taro-再帰関数Ⅲ(公開版).jtd 0. 目次 1 1. ソート 1 1. 1 挿入ソート 1 1. 2 クイックソート 1 1. 3 マージソート - 1 - 1 1. ソート 1 1. 1 挿入ソート 挿入ソートを再帰関数 isort を用いて書く 整列しているデータ (a[1] から a[n-1] まで ) に a[n] を挿入する操作を繰り返す 再帰的定義 isort(a[1],,a[n]) = insert(isort(a[1],,a[n-1]),a[n])

More information

PowerPoint Presentation

PowerPoint Presentation 最適化手法 第 回 工学部計数工学科 定兼邦彦 http://researchmap.jp/sada/resources/ 前回の補足 グラフのある点の隣接点をリストで表現すると説明したが, 単に隣接点の集合を持っていると思ってよい. 互いに素な集合のデータ構造でも, 単なる集合と思ってよい. 8 3 4 3 3 4 3 4 E v 重み 3 8 3 4 4 3 {{,},{3,8}} {{3,},{4,}}

More information

Taro-2分探索木Ⅰ(公開版).jtd

Taro-2分探索木Ⅰ(公開版).jtd 2 分探索木 Ⅰ 0. 目次 1. 2 分探索木とは 2. 2 分探索木の作成 3. 2 分探索木の走査 3. 1 前走査 3. 2 中走査 3. 3 問題 問題 1 問題 2 後走査 4. 2 分探索木の表示 - 1 - 1. 2 分探索木とは 木はいくつかの節点と節点同士を結ぶ辺から構成される 2 つの節点 u,v が直接辺で結ばれているとき 一方を親節点 他方を子節点という ある節点の親節点は高々

More information

Microsoft PowerPoint - DA2_2019.pptx

Microsoft PowerPoint - DA2_2019.pptx Johnon のアルゴリズム データ構造とアルゴリズム IⅠ 第 回最大フロー 疎なグラフ, 例えば E O( V lg V ) が仮定できる場合に向いている 隣接リスト表現を仮定する. 実行時間は O( V lg V + V E ). 上記の仮定の下で,Floyd-Warhall アルゴリズムよりも漸近的に高速 Johnon のアルゴリズム : アイデア (I) 辺重みが全部非負なら,Dikra

More information

( ) ( ) 30 ( ) 27 [1] p LIFO(last in first out, ) (push) (pup) 1

( ) ( ) 30 ( ) 27 [1] p LIFO(last in first out, ) (push) (pup) 1 () 2006 2 27 1 10 23 () 30 () 27 [1] p.97252 7 2 2.1 2.1.1 1 LIFO(last in first out, ) (push) (pup) 1 1: 2.1.2 1 List 4-1(p.100) stack[] stack top 1 2 (push) (pop) 1 2 void stack push(double val) val stack

More information

INTRODUCTION TO ALGORITHMS

INTRODUCTION TO ALGORITHMS 20.7.7 関根渓 ( 情報知識ネットワーク研究室 B4) INTRODUCTION TO LGORITHMS 6. Heapsort CONTENTS 6. ヒープ (Heap) 6.2 ヒープ条件の維持 (Maintaining the heap property) 6.3 ヒープの構成 (Building a heap) 6.4 ヒープソート (The heapsort algorithm)

More information

Microsoft Word - CompA-Ex doc

Microsoft Word - CompA-Ex doc コンパイラ演習参考資料 2008/09/23 担当 : 佐々木晃 算術式の処理と逆ポーランド記法 ( 第一回スライド 29 ページ ) (1) 実数値 (double の値 ) を格納するスタックを実装せよ ( 配列やリストを使うとよい ) (2) 逆ポーランド記法によって実数値の算術演算を行う計算機のプログラムを作成せよ 演算子や被演算子の各要素同士は空白で区切られるものとする (a) 四則演算のみなお

More information

長崎大学大学院生産科学研究科(博士前期課程)

長崎大学大学院生産科学研究科(博士前期課程) 問 1 次の文は 問題の把握からプログラムの完成までのプログラミング過程 を 5 段階に分けて示したものである 下記の [a.]~[x.] に当てはまる語句を記入せよ (ⅰ) 問題の把握と対策 : 何が問題か その問題を解決するにはどのようなシステムで対処するのかを考え, 全体を見渡して人手や機械で処理し部分と, 計算機で処理する部分とを明らかにする (ⅱ) プログラミングの設計 : フローチャートを用いてシステムの開発工程を管理することを考えると,

More information

アルゴリズムとデータ構造

アルゴリズムとデータ構造 講義 アルゴリズムとデータ構造 第 2 回アルゴリズムと計算量 大学院情報科学研究科情報理工学専攻情報知識ネットワーク研究室喜田拓也 講義資料 2018/5/23 今日の内容 アルゴリズムの計算量とは? 漸近的計算量オーダーの計算の方法最悪計算量と平均計算量 ポイント オーダー記法 ビッグオー (O), ビッグオメガ (Ω), ビッグシータ (Θ) 2 お風呂スケジューリング問題 お風呂に入る順番を決めよう!

More information

Microsoft PowerPoint - mp13-07.pptx

Microsoft PowerPoint - mp13-07.pptx 数理計画法 ( 数理最適化 ) 第 7 回 ネットワーク最適化 最大流問題と増加路アルゴリズム 担当 : 塩浦昭義 ( 情報科学研究科准教授 ) hiour@di.i.ohoku.c.jp ネットワーク最適化問題 ( 無向, 有向 ) グラフ 頂点 (verex, 接点, 点 ) が枝 (edge, 辺, 線 ) で結ばれたもの ネットワーク 頂点や枝に数値データ ( 距離, コストなど ) が付加されたもの

More information

Microsoft PowerPoint - IntroAlgDs-10-4.pptx

Microsoft PowerPoint - IntroAlgDs-10-4.pptx アルゴリズムとデータ構造入門-1 2010年10月12日 1 1-1-8 1 8 Procedures as Black Black- 大学院情報学研究科知能情報学専攻 知能メディア講座 音声メディア分野 1.2.1 1 2 1 Linear Recursion and Iteration 復習 htt://winnie.kuis.kyoto-u.ac.j/~okuno/lecture/10/introalgds/

More information

オートマトンと言語

オートマトンと言語 オートマトンと言語 4 回目 5 月 2 日 ( 水 ) 3 章 ( グラフ ) の続き 授業資料 http://ir.cs.yamanashi.ac.jp/~ysuzuki/public/automaton/ 授業の予定 ( 中間試験まで ) 回数月日 内容 4 月 日オートマトンとは, オリエンテーション 2 4 月 8 日 2 章 ( 数式の記法, スタック,BNF) 3 4 月 25 日 2

More information

Microsoft PowerPoint - kougi11.ppt

Microsoft PowerPoint - kougi11.ppt C プログラミング演習 中間まとめ 2 1 ソフトウエア開発の流れ 機能設計 外部仕様 ( プログラムの入力と出力の取り決め ) 構成設計 詳細設計 論理試験 内部データ構造や関数呼び出し方法などに関する取り決めソースプログラムの記述正しい入力データから正しい結果が得られるかテスト関数単位からテストをおこなう 耐性試験 異常な入力データに対して, 異常を検出できるかテスト異常終了することはないかテスト

More information

Microsoft PowerPoint - DA2_2017.pptx

Microsoft PowerPoint - DA2_2017.pptx // データ構造とアルゴリズム IⅠ 第 回単一始点最短路 (II)/ 全点対最短路 トポロジカル ソート順による緩和 トポロジカル ソート順に緩和 閉路のない有向グラフ限定 閉路がないならトポロジカル ソート順に緩和するのがベルマン フォードより速い Θ(V + E) 方針 グラフをトポロジカル ソートして頂点に線形順序を与える ソート順に頂点を選び, その頂点の出辺を緩和する 各頂点は一回だけ選択される

More information

memo

memo 数理情報工学演習第一 C プログラミング演習 ( 第 5 回 ) 2015/05/11 DEPARTMENT OF MATHEMATICAL INFORMATICS 1 今日の内容 : プロトタイプ宣言 ヘッダーファイル, プログラムの分割 課題 : 疎行列 2 プロトタイプ宣言 3 C 言語では, 関数や変数は使用する前 ( ソースの上のほう ) に定義されている必要がある. double sub(int

More information

PowerPoint Presentation

PowerPoint Presentation 二分探索木 今回の要点 二分探索木の構造 どのような条件を満たさねばならないか? 二分探索が効率よく出来るため 二分探索木の操作 探索の方法 挿入の方法 削除の方法 各操作の実装コード 二分探索木の性質 どのような形がもっと探索に適しているか? 二分探索木とは 木構造 枝分かれした構造を表現するのに適する 根から葉に向かってたどる = 探索 何らかの特徴を持って構成されていると探索しやすい 二分探索木

More information

Microsoft PowerPoint - IntroAlgDs pptx

Microsoft PowerPoint - IntroAlgDs pptx アルゴリズムとデータ構造入門 -4 202 年 0 月 23 日 大学院情報学研究科知能情報学専攻知能メディア講座音声メディア分野 http://wiie.kuis.kyoto-u.ac.jp/~okuo/lecture/0/itroalgds/ okuo@i.kyoto-u.ac.jp,okuo@ue.org TAの居室は文学部東館 4 階奥乃 研,2 研 if mod( 学籍番号の下 3 桁,3)

More information

Microsoft Word - NonGenTree.doc

Microsoft Word - NonGenTree.doc ジェネリクスとコンパレータを使用しない 2 分探索木のプログラム例 BinTreeNG.java: 2 分探索木のクラス BinTreeNG BinTreeTesterNG.java: BinTreeNG を利用するプログラム例 === BinTreeNG.java =========================================================================

More information

Delphi Generics.Collections

Delphi Generics.Collections Delphi Generics. Copyright(C) 2008 Embarcadero Technologies Delphi Generics.Collections 目次 Generics.Collections.TCollectionNo 1 Generics.Collections.TCollectionNo 3 Generics.Collections.TDictionary5 Generics.Collections.TDictionary.A

More information

バイオプログラミング第 1 榊原康文 佐藤健吾 慶應義塾大学理工学部生命情報学科

バイオプログラミング第 1 榊原康文 佐藤健吾 慶應義塾大学理工学部生命情報学科 バイオプログラミング第 1 榊原康文 佐藤健吾 慶應義塾大学理工学部生命情報学科 ポインタ変数の扱い方 1 ポインタ変数の宣言 int *p; double *q; 2 ポインタ変数へのアドレスの代入 int *p; と宣言した時,p がポインタ変数 int x; と普通に宣言した変数に対して, p = &x; は x のアドレスのポインタ変数 p への代入 ポインタ変数の扱い方 3 間接参照 (

More information

Microsoft PowerPoint - ruby_instruction.ppt

Microsoft PowerPoint - ruby_instruction.ppt Ruby 入門 流れ Ruby の文法 画面に出力 キーボードから入力 数値 文字列 変数 配列 ハッシュ 制御構造 ( 分岐 繰り返しなど ) if while case for each 関数 クラス Ruby とは プログラミング言語 インタプリタ言語 オブジェクト指向 国産 ウェブアプリケーションフレームワーク RubyOnRails で注目 弊社での Web アプリケーション開発に利用 画面に出力

More information

Taro-2分探索木Ⅱ(公開版).jtd

Taro-2分探索木Ⅱ(公開版).jtd 2 分探索木 Ⅱ 0. 目次 5. 2 分探索木の操作 5. 1 要素の探索 5. 2 直前の要素の探索 5. 3 直後の要素の探索 5. 4 要素の削除 5. 5 問題 問題 1-1 - 5. 2 分探索木の操作 5. 1 要素の探索 要素 44 の探索 (1) 要素 と 44 を比較して 左部分木をたどる (2) 要素 33 と 44 を比較して 右部分木をたどる (3) 要素 44 を見つけた

More information

Microsoft PowerPoint - ca ppt [互換モード]

Microsoft PowerPoint - ca ppt [互換モード] 大阪電気通信大学情報通信工学部光システム工学科 2 年次配当科目 コンピュータアルゴリズム 良いアルゴリズムとは 第 2 講 : 平成 20 年 10 月 10 日 ( 金 ) 4 限 E252 教室 中村嘉隆 ( なかむらよしたか ) 奈良先端科学技術大学院大学助教 y-nakamr@is.naist.jp http://narayama.naist.jp/~y-nakamr/ 第 1 講の復習

More information

PowerPoint Presentation

PowerPoint Presentation 整列アルゴリズムの基礎 この回の要点 整列とは? 整列処理の意味 整列の種類 整列の計算量 整列の安定性 単純な整列アルゴリズム バブルソート 選択ソート 挿入ソート それぞれのソートの特徴と実装 整列 (Sorting) とは 整列という操作 レコードの集まりを キーの値の大小関係に従って並べ替える操作 小さい 大きい = 昇順 (ascending order) 大きい 小さい = 降順 (descending

More information

Microsoft PowerPoint - mp11-06.pptx

Microsoft PowerPoint - mp11-06.pptx 数理計画法第 6 回 塩浦昭義情報科学研究科准教授 shioura@dais.is.tohoku.ac.jp http://www.dais.is.tohoku.ac.jp/~shioura/teaching 第 5 章組合せ計画 5.2 分枝限定法 組合せ計画問題 組合せ計画問題とは : 有限個の もの の組合せの中から, 目的関数を最小または最大にする組合せを見つける問題 例 1: 整数計画問題全般

More information

アルゴリズムとデータ構造

アルゴリズムとデータ構造 講義 アルゴリズムとデータ構造 第 3 回基本的なデータ構造 ( リスト スタック キュー ) 大学院情報科学研究科情報理工学専攻情報知識ネットワーク研究室喜田拓也 講義資料 2018/5/23 今日の内容 基本的なデータ構造リスト : 最も基本的なデータ集合の表現 配列 / 連結リスト / 双連結リストによる実装 スタック : 積み上げ式のデータ格納方式キュー : 入れた順に取り出せるデータ格納方式

More information

Programming D 1/15

Programming D 1/15 プログラミング D ML 大阪大学基礎工学部情報科学科中田明夫 nakata@ist.osaka-u.ac.jp 教科書 プログラミング言語 Standard ML 入門 6 章 2005/12/19 プログラミング D -ML- 1 2005/12/19 プログラミング D -ML- 2 補足 : 再帰関数の作り方 例題 : 整数 x,y( ただし x

More information

Microsoft Word - no206.docx

Microsoft Word - no206.docx 3.2 双方向リスト 今までのリストは 前から順にたどることしかできませんでした 今度は逆にもたどることができる 双方向リストを扱います この場合は 構造体には次を表すポインタの他に前を表すポインタを持つ ことになります 今回は最初と最後をポインタを使うと取り扱いが面倒になるので 最初 (start) と最後 (end) を どちらとも構造体 ( 値は意味を持たない ) を使うことにします こうすることによって

More information

はじめに コースの概要と目的 Oracle をより効率的に使用するための SQL のチューニング方法について説明します また 索引の有無 SQL の 記述方法がパフォーマンスにどのように影響するのかを実習を通して理解します 受講対象者 アプリケーション開発者 / データベース管理者の方 前提条件 S

はじめに コースの概要と目的 Oracle をより効率的に使用するための SQL のチューニング方法について説明します また 索引の有無 SQL の 記述方法がパフォーマンスにどのように影響するのかを実習を通して理解します 受講対象者 アプリケーション開発者 / データベース管理者の方 前提条件 S はじめに コースの概要と目的 Oracle をより効率的に使用するための SQL のチューニング方法について説明します また 索引の有無 SQL の 記述方法がパフォーマンスにどのように影響するのかを実習を通して理解します 受講対象者 アプリケーション開発者 / データベース管理者の方 前提条件 SQL トレーニング データベース アーキテクチャ コースを受講された方 もしくは同等の知識をお持ちの

More information

CプログラミングI

CプログラミングI C プログラミング I Swap 関数を作る Stack データ構造のための準備 整数変数 x と y の値を取り替える関数 swap を作る 最初の試み : swap-01.c #include void swap(int a, int b) { int tmp; tmp = a; a = b; b = tmp; int main(void) { int x=10, y=30;

More information

gengo1-8

gengo1-8 問題提起その 1 一文字ずつ文字 ( 数字 ) を読み込み それぞれの文字が何回入力されたかを数えて出力するプログラム int code, count_0=0, count_1=0, count_2=0, count_3=0,..., count_9=0; while( (code=getchar())!= EOF ){ } switch(code){ case 0 : count_0++; break;

More information

Microsoft PowerPoint - IntroAlgDs-05-4.ppt

Microsoft PowerPoint - IntroAlgDs-05-4.ppt アルゴリズムとデータ構造入門 2005 年 0 月 25 日 アルゴリズムとデータ構造入門. 手続きによる抽象の構築.2 Procedures and the Processes They generate ( 手続きとそれが生成するプロセス ) 奥乃 博. TUT Scheme が公開されました. Windows は動きます. Linux, Cygwin も動きます. 0 月 25 日 本日のメニュー.2.

More information

Microsoft PowerPoint - 10.pptx

Microsoft PowerPoint - 10.pptx m u. 固有値とその応用 8/7/( 水 ). 固有値とその応用 固有値と固有ベクトル 行列による写像から固有ベクトルへ m m 行列 によって線形写像 f : R R が表せることを見てきた ここでは 次元平面の行列による写像を調べる とし 写像 f : を考える R R まず 単位ベクトルの像 u y y f : R R u u, u この事から 線形写像の性質を用いると 次の格子上の点全ての写像先が求まる

More information

Python @HACHINONE 10 1 V Python 2014 2 : L[i] # -*- coding: utf-8 -*- def search(l, e): """L をリスト e をオブジェクトとする L に e が含まれていれば True そうでなければ False を返す """ for i in range(len(l)): if L[i] == e: return True

More information

Microsoft PowerPoint - qcomp.ppt [互換モード]

Microsoft PowerPoint - qcomp.ppt [互換モード] 量子計算基礎 東京工業大学 河内亮周 概要 計算って何? 数理科学的に 計算 を扱うには 量子力学を計算に使おう! 量子情報とは? 量子情報に対する演算 = 量子計算 一般的な量子回路の構成方法 計算って何? 計算とは? 計算 = 入力情報から出力情報への変換 入力 計算機構 ( デジタルコンピュータ,etc ) 出力 計算とは? 計算 = 入力情報から出力情報への変換 この関数はどれくらい計算が大変か??

More information

Microsoft Word - no12.doc

Microsoft Word - no12.doc 7.5 ポインタと構造体 構造体もメモリのどこかに値が格納されているのですから 構造体へのポインタ も存在します また ポインタも変数ですから 構造体のメンバに含めることができます まずは 構造体へのポインタをあつかってみます ex53.c /* 成績表 */ #define IDLENGTH 7 /* 学籍番号の長さ */ #define MAX 100 /* 最大人数 */ /* 成績管理用の構造体の定義

More information

Analysis of Algorithms

Analysis of Algorithms アルゴリズムの設計と解析 黄潤和 佐藤温 (TA) 2013.4~ Contents (L3 Search trees) Searching problems AVL tree 2-3-4 trees Red-Black trees 2 Searching Problems Problem: Given a (multi)set S of keys and a search key K, find

More information

Analysis of Algorithms

Analysis of Algorithms アルゴリズムの設計と解析 黄潤和 佐藤温 (TA) 2012.4~ Contents (L3 Search trees) Searching problems AVL tree 2-3-4 trees Red-Black tree 2 Searching Problems Problem: Given a (multi) set S of keys and a search key K, find

More information

オートマトンと言語

オートマトンと言語 オートマトンと言語 回目 4 月 8 日 ( 水 ) 章 ( 数式の記法, スタック,BNF 記法 ) 授業資料 http://ir.cs.yamanashi.ac.jp/~ysuzuki/public/automaton/ 授業の予定 ( 中間試験まで ) 回数月日 内容 4 月 日オートマトンとは, オリエンテーション 4 月 8 日 章 ( 数式の記法, スタック,BNF) 3 4 月 5 日

More information

nlp1-04a.key

nlp1-04a.key 自然言語処理論 I. 文法 ( 構文解析 ) その 構文解析 sytctic lysis, prsig 文の構文的な構造を決定すること句構造文法が使われることが多い文法による構文木は一般に複数ある 構文木の違い = 解釈の違い 構文解析の目的 句構造文法の規則を使って, 文を生成できる構文木を全て見つけだすこと 文法が入力文を生成できるかどうかを調べるだけではない pro I 構文解析とは 構文木の違い

More information

PowerPoint プレゼンテーション

PowerPoint プレゼンテーション コンパイラとプログラミング言語 第 10 週 Java 仮想マシンとその機械語 2014 年 6 月 11 日 金岡晃 授業計画 第 1 週 (4/9) コンパイラの概要 第 8 週 (5/28) 下向き構文解析 / 構文解析プログラム 第 2 週 (4/16) コンパイラの構成 第 9 週 (6/4) 中間表現と意味解析 第 3 週 (4/23) プログラミング言語の形式的な記述 第 10 週 (6/11)

More information

PowerPoint プレゼンテーション

PowerPoint プレゼンテーション プログラミング応用演習 第 4 回再帰的構造体 前回の出席確認演習 #include int main() { FILE *fp; int c, linecount, length, maxlength; fp=fopen("/usr/share/dict/words","r"); if (fp == NULL) return 1; linecount=0; length=0;

More information

Microsoft PowerPoint - DA1_2018.pptx

Microsoft PowerPoint - DA1_2018.pptx 木の利用例 ( ゲーム木 ) データ構造とアルゴリズム ⅠB 第 回 自分の手番 / 相手の手番で分岐していく 77 例題 二人で交代に,1 から順に までの数を言う. 言う数の個数は,1 個, 個,3 個のいずれか好きなのを選んでよい 最後に を言った方が負け 必勝法 を言って, 相手に順番を回せば絶対勝ち 一方,0 を言って, 相手に順番を回せば, 相手が何個を選んでも, 次に を言える ---

More information

模擬試験問題(第1章~第3章)

模擬試験問題(第1章~第3章) 基本情報技術者試験の練習問題 - 第 10 回 この問題は平成 19 年度春期の問題から抜粋しています 問 1 次のプログラムの説明及びプログラムを読んで, 設問 1~3 に答えよ プログラムの説明 整数型の 1 次元配列の要素 A[0],,A[N](N>0) を, 挿入ソートで昇順に整列する副プログラム InsertSort である (1) 挿入ソートの手順は, 次のとおりである (i) まず,A[0]

More information