Голова уже, даже не квадратная. В чем проблема?
package com.javarush.task.task20.task2027;
import java.util.ArrayList;
import java.util.List;
/*
Кроссворд
*/
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', 'e', 'm', 'o', '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) {
char[] letters = null;
String str="", strWord="";
int x1, y1;
List<Word> mass = new ArrayList<>();
List<Integer> numLettersY = new ArrayList<>();
List<Integer> numLettersX = new ArrayList<>();
int len;
for(int i = 0; i<words.length; i++)//определяем индекс слова
{
letters = words[i].toCharArray(); //разбиваем слово на массив букв
len=letters.length;
for (int x = 0; x < crossword.length; x++) //определяем позицию строки в массиве кроссворда
{
for (int y = 0; y < crossword[x].length; y++) //определяем позицию буквы в строке массива букв
{
if ((int) letters[0] == crossword[x][y]) //определяем равенство буквы из слова с буквой в кроссворде
{
if(len<=x){/*1*/
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x-s][y];
numLettersY.add(y);
numLettersX.add(x-s);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
if(len-1<=x&crossword[x].length-len>=y){ /*2*/
strWord+=(char)crossword[x][y];
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x-s][y+s];
numLettersY.add(y+s);
numLettersX.add(x-s);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
if(crossword[x].length-len>=y){ /*3*/
strWord+=(char)crossword[x][y];
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x][y+s];
numLettersY.add(y+s);
numLettersX.add(x);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
if(x+len<=crossword.length&crossword[x].length-len>=y){ /*4*/
strWord+=(char)crossword[x][y];
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x+s][y+s];
numLettersY.add(y+s);
numLettersX.add(x+s);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
if(crossword.length-len>=x){ /*5*/
strWord+=(char)crossword[x][y];
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x+s][y];
numLettersY.add(y);
numLettersX.add(x+s);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
if(crossword.length-len>=x&y+1>=len){ /*6*/
strWord+=(char)crossword[x][y];
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x+s][y-s];
numLettersY.add(y-s);
numLettersX.add(x+s);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
if(y+1>=len){ /*7*/
strWord+=(char)crossword[x][y];
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x][y-s];
numLettersY.add(y-s);
numLettersX.add(x);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
if(y+1>=len&x+1>=len){ /*8*/
strWord+=(char)crossword[x][y];
numLettersY.add(y);
numLettersX.add(x);
for(int s=1; s<len;s++){
strWord+=(char)crossword[x-s][y-s];
numLettersY.add(y-s);
numLettersX.add(x-s);
}
if(strWord.equals(words[i])==true)
{
Word word = new Word(words[i]);
word.setStartPoint(numLettersY.get(0), numLettersX.get(0));
word.setEndPoint(numLettersY.get(numLettersY.size()-1), numLettersX.get(numLettersX.size()-1));
mass.add(word);
numLettersX.clear();
numLettersY.clear();
strWord="";
}else {
x=numLettersX.get(0);
y=numLettersY.get(0);
numLettersX.clear();
numLettersY.clear();
strWord="";
}
}
}
}
}
}
System.out.println(mass.size());
for(int i =0; i<mass.size();i++)
{
System.out.println(mass.get(i).toString());
}
return mass;
}
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);
}
}
}