I get the correct output but it cannot pass the verification. I'm getting crazy with these non-solvable tasks. Someone please help me.
package com.codegym.task.task20.task2027;
import java.util.ArrayList;
import java.util.List;
/*
Word search
*/
public class Solution {
public static void main(String[] args) {
int[][] wordSearch = new int[][]{
{'f', 'd', 'e', 'r', 'l', 'e'},
{'u', 's', 'a', 'm', 'e', 'm'},
{'l', 'n', 'g', 'r', 'o', 'o'},
{'m', 'l', 'p', 'r', 'r', 'h'},
{'p', 'o', 'e', 'e', 'j', 'j'}
};
detectAllWords(wordSearch, "home", "same");
/*
Expected result
home - (5, 3) - (2, 0)
same - (1, 1) - (4, 1)
*/
}
public static List<Word> detectAllWords(int[][] wordSearch, String... words) {
List<Word> wordList = new ArrayList<>();
for (String word:words){ //Search for each word
char firstLetter = word.charAt(0);
wordLoop: for (int i = 0; i < wordSearch.length; i++){
for (int j = 0; j < wordSearch[i].length; j++){
if (firstLetter == wordSearch[i][j]){
List<Word> wrds = findWord(wordSearch, word, i, j);
if (wrds != null){
wordList.addAll(wrds);
break wordLoop;
}
}
}
}
}
System.out.println(wordList.toString());
return wordList;
}
private static List<Word> findWord(int[][] wTbl, String word, int x, int y){
List<Word> anotherList = new ArrayList<>();
int len = word.length() - 1;
int a , b;
StringBuilder sb = new StringBuilder();
//Loop 1 : Vertical Downward
if(y + len <= wTbl[x].length){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i <= len; i++){
sb.append((char) wTbl[a][b++]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x, y + len);
anotherList.add(wrd);
}
}
//Loop 2 : Diagonal Down-Right wise
if(x + len <= wTbl.length && y + len <= wTbl[x].length){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i <= len; i++){
sb.append((char) wTbl[a++][b++]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x + len, y + len);
anotherList.add(wrd);
}
}
//Loop 3 : Horizontal Right wise
if(x + len <= wTbl.length){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i <= len; i++){
sb.append((char) wTbl[a++][b]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x + len, y);
anotherList.add(wrd);
}
}
//Loop 4 : Diagonal Up-Right wise
if(x + len <= wTbl.length && y - len >= 0){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i <= len; i++){
sb.append((char) wTbl[a++][b--]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x + len, y - len);
anotherList.add(wrd);
}
}
//Loop 5 : Vertical Upward
if(y - len >= 0){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i <= len; i++){
sb.append((char) wTbl[a][b--]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x, y - len);
anotherList.add(wrd);
}
}
//Loop 6 : Diagonal Up-Left wise
if(x - len >= 0 && y - len >= 0){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i <= len; i++){
sb.append((char) wTbl[a--][b--]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x - len, y - len);
anotherList.add(wrd);
}
}
//Loop 7 : Horizontal Left wise
if(x - len >= 0){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i <= len; i++){
sb.append((char) wTbl[a--][b]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x - len, y);
anotherList.add(wrd);
}
}
//Loop 8 : Diagonal Down-Left wise
if(y + len <= wTbl[x].length && x - len >= 0){
a = x;
b = y;
sb = new StringBuilder();
for (int i = 0; i < len; i++){
sb.append(wTbl[a--][b++]);
}
if (sb.toString().equals(word)){
Word wrd = new Word(word);
wrd.setStartPoint(x, y);
wrd.setEndPoint(x - len, y + len);
anotherList.add(wrd);
}
}
return anotherList;
}
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);
}
}
}