758
コメント:
|
1751
|
削除された箇所はこのように表示されます。 | 追加された箇所はこのように表示されます。 |
行 4: | 行 4: |
行 5: | 行 6: |
真ん中あたりにデータを追加する場合を考えると分かります。 |
|
行 6: | 行 9: |
---- | |
行 14: | 行 17: |
'''null'''はシステムで用意されている'''定数'''です。 * 参照型の変数はnullで初期化されます。 * どこも参照していないことを表します。 ---- 追加 |
|
行 15: | 行 24: |
---- 削除 |
|
行 16: | 行 27: |
---- === サンプル === 値としてItemクラスのインスタンスを使った例です。 |
|
行 17: | 行 31: |
{{{#!java public class List1 { Item val; List1 link; void dispList() { List1 x; x = this; while(x != null) { x.val.disp(); x = x.link; } } public static void main(String[] args) { List1 a; List1 b; List1 c; a = new List1(); a.val = new Food("パン", 150, 200.0, 200.0); b = new List1(); a.link = b; b.val = new Drink("コーヒー", 120, 250); c = new List1(); b.link = c; c.val = new Food("みかん", 100, 150.0, 200.0); a.dispList(); } } }}} |
線形リスト
線形リストは同じ形式のデータが一列に並んだものです。
データの追加や削除が配列と比べて楽に行えます。
真ん中あたりにデータを追加する場合を考えると分かります。
Javaで記述してみましょう。
このようなインスタンスを使います。
3つのインスタンスをつないだ例を示します。
nullはシステムで用意されている定数です。
- 参照型の変数はnullで初期化されます。
- どこも参照していないことを表します。
追加
削除
サンプル
値としてItemクラスのインスタンスを使った例です。
1 public class List1 2 { 3 Item val; 4 List1 link; 5 6 void dispList() 7 { 8 List1 x; 9 10 x = this; 11 while(x != null) 12 { 13 x.val.disp(); 14 x = x.link; 15 } 16 } 17 18 public static void main(String[] args) 19 { 20 List1 a; 21 List1 b; 22 List1 c; 23 24 a = new List1(); 25 a.val = new Food("パン", 150, 200.0, 200.0); 26 b = new List1(); 27 a.link = b; 28 b.val = new Drink("コーヒー", 120, 250); 29 c = new List1(); 30 b.link = c; 31 c.val = new Food("みかん", 100, 150.0, 200.0); 32 33 a.dispList(); 34 } 35 }