Loading...

Във форума е въведено ограничение, което позволява на потребителите единствено да разглеждат публикуваните въпроси.

MartinBG avatar MartinBG 4803 Точки
Best Answer

Примерно решение на задачата с използване на рекурсия и Depth-first search (DFS).

 

Работата се извършва от този статичен метод:

    private static void fill(char[][] matrix, int row, int col, char fillChar, char startChar) {
        if (matrix[row][col] != startChar) {
            return; // recursion current path ends when char at current position is not startChar
        }

        matrix[row][col] = fillChar;

        if (row + 1 < matrix.length) { // up
            fill(matrix, row + 1, col, fillChar, startChar); // recursion
        }

        if (row - 1 >= 0) { // down
            fill(matrix, row - 1, col, fillChar, startChar); // recursion
        }

        if (col + 1 < matrix[row].length) { // left
            fill(matrix, row, col + 1, fillChar, startChar); // recursion
        }

        if (col - 1 >= 0) { // right
            fill(matrix, row, col - 1, fillChar, startChar); // recursion
        }
    }

Ако нямате предишен опит с рекурсивни функции и алгоритми, може да Ви е доста трудно да осмислите какво точно се случва и как работи, но с повече дебъгване и четене по темата, ще успеете.

 

0
04/06/2020 17:37:12
AlexNestorov42 avatar AlexNestorov42 7 Точки

Благодаря много!

1
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.