Вроде возвращаю только 2 объекта (мне передают 2 слова, я возвращаю их координаты в кроссворде, правильно я думаю?). Но валидатор мне доказывает, что я возвращаю массив с не правильным количеством объектов. Что я делаю не так? Возможно в цикле что-то не так, но если нужно осмотреть программу целиком, то вот что он (по моему мнению должен) делать:
Перебирает все значения в двухмерном массиве (сначала берётся 1-на координата x, и к ней приравниваются все координаты y, если же в даной строке x нету соответствующих значений, то цикл увеличивает значение x, и так до конца. Если же значение первой буквы совпало, то присваивается значение x и y соответствующим полям: WordStarX и WordStartY. То же самое работает с конечными координатами слова. Если же все поля координат (WordStartX, WordStartY, WordEndX, WordEndY) заполнены, то цикл завершается (я сначала это не предусмотрел, но уже добавил) и создаётся объект типа Word с соответствующими данными. То же самое другой цикл (но для другого объекта типа Word).
package com.javarush.task.task20.task2027;
import java.util.List;
import java.util.ArrayList;
/*
Кроссворд
*/
public class Solution {
public static void main(String[] args) {
int[][] crossword = new int[][]{
{'f', 'd', 'e', 'r', 'l', 'k'},
{'u', 's', 'a', 'm', 'e', 'o'},
{'l', 'n', 'g', 'r', 'o', 'v'},
{'m', 'l', 'p', 'r', 'r', 'h'},
{'p', 'o', 'e', 'e', 'j', 'j'}
};
detectAllWords(crossword, "home", "same");
/*
Ожидаемый результат
home - (5, 3) - (2, 0)
same - (1, 1) - (4, 1)
*/
}
public static List<Word> detectAllWords(int[][] crossword, String... words) {
String firstWord = words[0];
String secondWord = words[1];
Word word = new Word(firstWord);
Word word2 = new Word(secondWord);
int WordStartX = 0;
int WordStartY = 0;
int WordEndX = 0;
int WordEndY = 0;
char[] firstWordChars = firstWord.toCharArray();
char[] secondWordChars = secondWord.toCharArray();
ArrayList<Word> list = new ArrayList<Word>();
for (int x = 0; x < 5; x++){
for (int y = 0; y < 4; y++){
if (WordStartX != 0 && WordStartY != 0 && WordEndX != 0 && WordEndY != 0){
word.setStartPoint(WordStartX, WordStartY);
word.setEndPoint(WordEndX, WordEndY);
}
else if (crossword[x][y] == firstWordChars[0]){
WordStartX = x;
WordStartY = y;
}
else if (crossword[x][y] == firstWordChars[firstWordChars.length-1]){
WordEndX = x;
WordEndY = y;
}
}
}
list.add(word);
for (int x = 0; x < 5; x++){
for (int y = 0; y < 4; y++){
if (WordStartX != 0 && WordStartY != 0 && WordEndX != 0 && WordEndY != 0){
word.setStartPoint(WordStartX, WordStartY);
word.setEndPoint(WordEndX, WordEndY);
}
else if (crossword[x][y] == secondWordChars[0]){
WordStartX = x;
WordStartY = y;
}
else if (crossword[x][y] == secondWordChars[secondWordChars.length-1]){
WordEndX = x;
WordEndY = y;
}
}
}
list.add(word2);
return list;
}
public static class Word {
private String text;
private int startX;
private int startY;
private int endX;
private int endY;
public Word(String text) {
this.text = text;
}
public void setStartPoint(int i, int j) {
startX = i;
startY = j;
}
public void setEndPoint(int i, int j) {
endX = i;
endY = j;
}
@Override
public String toString() {
return String.format("%s - (%d, %d) - (%d, %d)", text, startX, startY, endX, endY);
}
}
}