-
Notifications
You must be signed in to change notification settings - Fork 0
/
ReaderTournament
164 lines (120 loc) · 4.77 KB
/
ReaderTournament
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
class ColEdge1 {
int u;
int v;
}
class customArray1 {
int breakIndex;
int number;
public customArray1(int breakpoint, int n) {
breakIndex = breakpoint;
number = n;
}
@Override
public String toString() {
return breakIndex + "," + number;
}
}
public class Reader {
public static int edges;
public static int vertices;
public final static boolean DEBUG = true;
public final static String COMMENT = "//";
public int vertices1;
public int edges1;
/**
* this method makes an adjacency matrix based on the file the user uploads.
* @param inputfile is the path for the graph the user wants to upload
* @return an adjacency matrix based on the file
*/
public static int[][] readCreateMatrix(String inputfile) {
boolean seen[] = null;
//! n is the number of vertices in the graph
int n = -1;
//! m is the number of edges in the graph
int m = -1;
//! e will contain the edges of the graph
ColEdge1 e[] = null;
try {
FileReader fr = new FileReader(inputfile);
BufferedReader br = new BufferedReader(fr);
String record = new String();
//! THe first few lines of the file are allowed to be comments, staring with a // symbol.
//! These comments are only allowed at the top of the file.
//! -----------------------------------------
while ((record = br.readLine()) != null) {
if (record.startsWith("//")) continue;
break; // Saw a line that did not start with a comment -- time to start reading the data in!
}
if (record.startsWith("VERTICES = ")) {
n = Integer.parseInt(record.substring(11));
if (DEBUG) System.out.println(COMMENT + " Number of vertices = " + n);
}
seen = new boolean[n + 1];
record = br.readLine();
if (record.startsWith("EDGES = ")) {
m = Integer.parseInt(record.substring(8));
if (DEBUG) System.out.println(COMMENT + " Expected number of edges = " + m);
}
e = new ColEdge1[m];
for (int d = 0; d < m; d++) {
if (DEBUG) System.out.println(COMMENT + " Reading edge " + (d + 1));
record = br.readLine();
String data[] = record.split(" ");
if (data.length != 2) {
System.out.println("Error! Malformed edge line: " + record);
System.exit(0);
}
e[d] = new ColEdge1();
e[d].u = Integer.parseInt(data[0]);
e[d].v = Integer.parseInt(data[1]);
seen[e[d].u] = true;
seen[e[d].v] = true;
if (DEBUG) System.out.println(COMMENT + " Edge: " + e[d].u + " " + e[d].v);
}
String surplus = br.readLine();
if (surplus != null) {
if (surplus.length() >= 2) if (DEBUG)
System.out.println(COMMENT + " Warning: there appeared to be data in your file after the last edge: '" + surplus + "'");
}
} catch (IOException ex) {
// catch possible io errors from readLine()
System.out.println("Error! Problem reading file " + inputfile);
System.exit(0);
}
for (int x = 1; x <= n; x++) {
if (seen[x] == false) {
if (DEBUG)
System.out.println(COMMENT + " Warning: vertex " + x + " didn't appear in any edge : it will be considered a disconnected vertex on its own.");
}
}
vertices = n;
edges = m;
int[][] matrix = new int[vertices + 1][vertices + 1]; // creating adjacency matrix based on the amount of vertices.
for (int i = 0; i < e.length; i++) {
int firstNumber = e[i].u; // the matrix is created based on the pairs from the graphs provided
int secondNumber = e[i].v;
matrix[firstNumber][secondNumber] = 1;
matrix[secondNumber][firstNumber] = 1;
}
return matrix;
}
public static int getEdges(){
return edges;
}
public static int getVertices(){
return vertices;
}
public static double[][] doubleMat (int[][] adjMat){
double[][] doubleMatrix = new double[adjMat.length][adjMat.length];
for(int i = 0;i<adjMat.length;i++){
for(int j =0;j<adjMat.length;j++){
double placeHolder = (double) adjMat[i][j];
doubleMatrix[i][j] = placeHolder;
}
}
return doubleMatrix;
}
}