annotate src/main/csharp/jp.ac.u-ryukyu.ie.cr/jungle/store/impl/DefaultNodePath.cs @ 8:d132d442dc34

List fix and Code delete
author Kazuma
date Wed, 12 Oct 2016 22:56:14 +0900
parents 02b2ab7bffe6
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
1 using UnityEngine;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
2 using System.Collections.Generic;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
3 using System.Collections;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
4
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
5 public class DefaultNodePath : NodePath {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
6 private List<int> path = new List<int>();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
7
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
8 IEnumerator IEnumerable.GetEnumerator()
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
9 {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
10 // call the generic version of the method
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
11 return this.GetEnumerator();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
12 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
13
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
14 public IEnumerator<int> GetEnumerator()
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
15 {
7
Kazuma
parents: 0
diff changeset
16 return path.iterator ();
0
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
17 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
18
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
19 public DefaultNodePath() {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
20 path = new List<int> ().addLast (-1);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
21 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
22
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
23 private DefaultNodePath(List<int> path) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
24 this.path = path;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
25 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
26
7
Kazuma
parents: 0
diff changeset
27 /// <summary>
Kazuma
parents: 0
diff changeset
28 /// Listに追加します。
Kazuma
parents: 0
diff changeset
29 /// path = path.add(0)を2回する
Kazuma
parents: 0
diff changeset
30 /// path = path.add(0).add(0)する
Kazuma
parents: 0
diff changeset
31 /// これは同じ
Kazuma
parents: 0
diff changeset
32 /// </summary>
Kazuma
parents: 0
diff changeset
33 /// <param name="pos">Position.</param>
0
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
34
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
35 public NodePath add(int pos) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
36 List<int> newPath = path.addLast(pos);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
37 return new DefaultNodePath(newPath);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
38 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
39
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
40 public Pair<int, NodePath> pop() {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
41 int head = path.headList();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
42 List<int> tail = path.deleteHead();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
43 return new Pair<int, NodePath>(head, new DefaultNodePath(tail));
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
44 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
45
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
46 public Pair<int, NodePath> last() {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
47 int last = path.headList();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
48 List<int> list = path.deleteHead();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
49 return new Pair<int, NodePath>(last, new DefaultNodePath(list));
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
50 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
51
7
Kazuma
parents: 0
diff changeset
52 public override string ToString() {
8
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
53 string s = "List <";
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
54 int list_count = this.path.length();
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
55 int count = 0;
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
56 foreach(var i in this.path) {
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
57 if (count != list_count -1){
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
58 s += i.ToString() + ",";
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
59 } else {
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
60 s += i.ToString();
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
61 }
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
62 count++;
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
63 }
d132d442dc34 List fix and Code delete
Kazuma
parents: 7
diff changeset
64 return s + ">";
0
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
65 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
66
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
67 public int size() {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
68 return path.length();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
69 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
70
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
71 public NodePath tail() {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
72 List<int> tail = path.deleteLast ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
73 return new DefaultNodePath (tail);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
74 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
75
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
76 public List<DefaultNodePath> inits() {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
77 List<DefaultNodePath> paths = new List<DefaultNodePath> ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
78 List<int> coursePath = new List<int> ();
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
79 foreach (int tmpPath in path) {
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
80 List<int> tmp = coursePath.addLast (tmpPath);
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
81 paths = paths.addLast (new DefaultNodePath (tmp));
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
82 coursePath = tmp;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
83 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
84 return paths;
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
85 }
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
86
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
87
dec15de2c6ff first commit
Kazuma
parents:
diff changeset
88 }