| 1 | ヨコ型探索 |
| 2 | |
| 3 | {{{ |
| 4 | S |
| 5 | AD |
| 6 | DBC |
| 7 | BCEH |
| 8 | CEH |
| 9 | EH |
| 10 | HFG |
| 11 | FGIJ |
| 12 | GIJ |
| 13 | IJ |
| 14 | }}} |
| 15 | |
| 16 | 最良優先探索 |
| 17 | |
| 18 | 候補節点の中から解の可能性が高いものを優先的に選択できるように工夫した探索法のひとつ |
| 19 | ヒューリスティック関数h(x)をたとえば街区画距離と定義して、hの値が小さいほうがそれっぽいんじゃねとかやってみる |
| 20 | |
| 21 | |
| 22 | === 木構造 === |
| 23 | |
| 24 | * 組織図、系統図のたぐい |
| 25 | |
| 26 | * 二次元的な広がりを持つ階層構造 |
| 27 | |
| 28 | * 階層的かつ再帰的 (つまり、ある節から下をもとの木からもぎ取るとその節を根とする新しい木ができる。これをsubtreeという) |
| 29 | |
| 30 | かっこ表記: Lispみたいなかっこだらけのnotation |
| 31 | {{{ |
| 32 | (A |
| 33 | (B |
| 34 | (E) |
| 35 | (F) |
| 36 | ) |
| 37 | ) |
| 38 | }}} |
| 39 | |
| 40 | 度数: 節から下に出ている枝の数 |
| 41 | 葉: 末端 |
| 42 | |
| 43 | 二分木: |
| 44 | |
| 45 | 定義: |
| 46 | 二分木とは、節の有限集合であって、"空集合" XOR "根と2個の違い素な二分木とからなる" (左右の区別が可能) |
| 47 | 二進木とはちがう |
| 48 | 二分木は、たとえ部分木の片方が空集合でも、部分木の左右が区別できる (空集合でもとりあえず存在は認知する) |
| 49 | |
| 50 | 完全二分木 |
| 51 | |
| 52 | 二分木の走査 |
| 53 | 先順、中順、後順 |
| 54 | |
| 55 | 先順 |
| 56 | visit(p->record); |
| 57 | trav(p->left); |
| 58 | trav(p->right); |
| 59 | |
| 60 | chuujun |
| 61 | trav(p->left); |
| 62 | visit(p->record); |
| 63 | r |
| 64 | |
| 65 | atojun |
| 66 | left |
| 67 | right |
| 68 | record |
| 69 | |
| 70 | ポーランド記法 |
| 71 | a*(b+c) は *a+bcと表す |
| 72 | 木構造に書いて、横型探索を適用するとわかりやすい |
| 73 | |
| 74 | 逆ポーランド記法 |
| 75 | スタック操作で実現 |
| 76 | 数字を食わせる→演算子を食わせる→直前の二項について演算が行われる→また演算子を食わせる→演算が行われる→答えが出る |
| 77 | |
| 78 | もっと丁寧にノートとりたい |