-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGraafKatsed.java
87 lines (76 loc) · 2.72 KB
/
GraafKatsed.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import ee.ut.dendroloj.Dendrologist;
import ee.ut.dendroloj.GraphCanvas;
import java.awt.*;
import java.util.ArrayList;
import java.util.List;
public class GraafKatsed {
public static void main(String[] args) {
{
String[] nimed = new String[]{
"A",
"B",
"C",
"D",
"E"
};
int[][] M = {
{0, 11, 1, 12, -1},
{4, 0, 2, -1, 6},
{-1, 2, 0, 3, -1},
{12, -1, -1, 0, -1},
{-1, -1, 5, 4, 123}
};
GraphCanvas<Integer> lõuend = new GraphCanvas<>();
for (int i = 0; i < M.length; i++) {
lõuend.drawVertex(i, nimed[i]);
}
for (int i = 0; i < M.length; i++) {
for (int j = 0; j < M.length; j++) {
if (i != j && M[i][j] != -1) lõuend.drawDirectedEdge(i, j, M[i][j]);
}
}
Dendrologist.drawGraph(lõuend);
}
{
List<Tipp> tipud = new ArrayList<>();
tipud.add(new Tipp("A", 1, 0));
tipud.add(new Tipp("B", 2, 5));
tipud.add(new Tipp("C", 0, 1));
tipud.add(new Tipp("D", 1, 1));
tipud.add(new Tipp("E", 0, 0));
tipud.get(0).kaared.add(new Kaar(11, tipud.get(1)));
tipud.get(0).kaared.add(new Kaar(22, tipud.get(2)));
tipud.get(3).kaared.add(new Kaar(31, tipud.get(2)));
tipud.get(4).kaared.add(new Kaar(0, tipud.get(4)));
tipud.get(4).kaared.add(new Kaar(7, tipud.get(2)));
GraphCanvas<Tipp> lõuend = new GraphCanvas<>();
for (Tipp tipp : tipud) {
lõuend.drawFixedVertex(tipp, tipp.x, tipp.y, tipp.tähis);
for (Kaar kaar : tipp.kaared) {
lõuend.drawEdge(tipp, kaar.lõppTipp, kaar.kaal);
}
}
Dendrologist.drawGraph(lõuend);
}
}
private static class Tipp {
public final String tähis;
public final double x;
public final double y;
public final List<Kaar> kaared;
public Tipp(String tähis, double x, double y) {
this.tähis = tähis;
this.x = x;
this.y = y;
this.kaared = new ArrayList<>();
}
}
private static class Kaar {
final int kaal;
final Tipp lõppTipp;
public Kaar(int kaal, Tipp lõppTipp) {
this.kaal = kaal;
this.lõppTipp = lõppTipp;
}
}
}