Все, что я пытаюсь сделать, это сравнить два односимвольных строковых атрибута, используя метод .equals (), чтобы определить, является ли объект узла "начальным узлом" или "целевым узлом"
Мой код выглядит следующим образом:
public Node findStart(ArrayList<Node> a)
{
if (a.size() > 0)
{
for (Node n : a)
{
if (n.getVal().equalsIgnoreCase("S"))
n.setStart(true);
return n;
}
}
System.out.println("no starting node found");
return null;
}
public Node findGoal(ArrayList<Node> a)
{
if (a.size()>0)
{
for (Node n: a)
{
if (n.getVal().equalsIgnoreCase("G"))
n.setGoal(true);
return n;
}
}
System.out.println("no goal node found");
return null;
}
к сожалению, вывод, который я получаю, неверен и выглядит следующим образом:
the starting node is:
Ab
the goal nodes are: Ab
the goal nodes are: Ab
the goal nodes are: Ab
the goal nodes are: Ab
справочная информация такова:
У меня есть программа, которая считывает текстовые файлы, которые содержат данные в виде простых матриц, аналогично следующему:
~ val Ab Cd Ef Gh Ij Kl Mn
AB ~ ~ 1 1 ~ ~ ~ ~
CD ~ 1 ~ ~ 1 ~ ~ ~
EF G 4 ~ ~ 1 ~ ~ ~
GH ~ 2 2 ~ ~ ~ 8 2
IJ S ~ 2 ~ 3 ~ ~ 1
KL ~ ~ ~ 2 5 ~ ~ 1
MN ~ ~ ~ ~ 3 4 1 ~
матрицы текстового файла представляют собой графики, где числа представляют расстояние от края, соединяющего дваузлы и буквы обозначают, является ли узел отправной точкой или целевой точкой графа.
моя программа выводит следующее при чтении в этом текстовом файле:
Node AB, abbrev Ab, value ~
AB has edge to: CD labeled: 1
AB has edge to: EF labeled: 1
AB has edge from: CD labeled: 1
AB has edge from: EF labeled: 4
AB has edge from: GH labeled: 2
Node CD, abbrev Cd, value ~
CD has edge to: AB labeled: 1
CD has edge to: GH labeled: 1
CD has edge from: AB labeled: 1
CD has edge from: GH labeled: 2
CD has edge from: IJ labeled: 2
Node EF, abbrev Ef, value G
EF has edge to: AB labeled: 4
EF has edge to: GH labeled: 1
EF has edge from: AB labeled: 1
EF has edge from: KL labeled: 2
Node GH, abbrev Gh, value ~
GH has edge to: AB labeled: 2
GH has edge to: CD labeled: 2
GH has edge to: KL labeled: 8
GH has edge to: MN labeled: 2
GH has edge from: CD labeled: 1
GH has edge from: EF labeled: 1
GH has edge from: IJ labeled: 3
GH has edge from: KL labeled: 5
GH has edge from: MN labeled: 3
Node IJ, abbrev Ij, value S
IJ has edge to: CD labeled: 2
IJ has edge to: GH labeled: 3
IJ has edge to: MN labeled: 1
IJ has edge from: MN labeled: 4
Node KL, abbrev Kl, value ~
KL has edge to: EF labeled: 2
KL has edge to: GH labeled: 5
KL has edge to: MN labeled: 1
KL has edge from: GH labeled: 8
KL has edge from: MN labeled: 1
Node MN, abbrev Mn, value ~
MN has edge to: GH labeled: 3
MN has edge to: IJ labeled: 4
MN has edge to: KL labeled: 1
MN has edge from: GH labeled: 2
MN has edge from: IJ labeled: 1
MN has edge from: KL labeled: 1