0 / 0 / 0
Регистрация: 06.11.2012
Сообщений: 5
|
||||||
1 | ||||||
Найти ошибку в методе поиска локального минимума в двухмерном массиве08.11.2012, 20:27. Показов 1256. Ответов 7
Метки нет (Все метки)
Задача по поиску локального минимума в двумерном массиве. Локальным минимумом считается значение, которое строго меньше всех его соседей. Проверку на локальный минимум реализовал в отдельном методе, вот он:
Кликните здесь для просмотра всего текста
В результате выходит совсем не то. Пожалуйста, помогите разобраться, где я накосячил. Не ругайте особо, самообучаюсь.
0
|
08.11.2012, 20:27 | |
Ответы с готовыми решениями:
7
Найти номер первого локального минимума в массиве Найти номер его первого локального минимума в массиве Метод для поиска локального минимума в классе Array Поиск максимума и минимума в двухмерном массиве textbox |
179 / 48 / 6
Регистрация: 23.06.2011
Сообщений: 248
|
|
09.11.2012, 00:53 | 2 |
Ты сам себя запутал.
Твоя ошибка в том, что ты не понял, зачем именно создал метод. Судя по возвращаемому значению и аргументам, ты передаешь позицию в массиве и проверяешь, является ли она локальным минимумом. Это делается в одну строчку с кучей && Представь морской бой. Ты стреляешь в ячейку и просто проверяешь все остальные вокруг нее. Так как у нас есть условия краев и углов, у тебя будет 4 условия проверки углов и 4 условия проверки краев + 1 условие проверки середины. Итого - 9 строчек. В твоем же коде ты зачем-то делаешь кучу переборов значений каких-то, используешь кучу лишних переменных, условий.. в общем, голову сломаешь ) Код должен быть как можно более лаконичным. Не используй много лишних переменных, не используй непонятных названий, с другой стороны, не экономь на переменных. Все в меру. Не экономь на памяти, использование sbyte никому лучше не сделает, чтобы тебя не мучила жадность и совесть - компилятор все равно переделает их скорее всего в int. Четко понимай, что ты реализуешь в том или ином методе. Не пытайся запихать все в один метод, но и не создавай кучу новых ради выполнения одной операции. Очень советую не отказываться от бумаги с ручкой и рисовать алгоритмы и блок-схемы. Это очень помогает. Поначалу рисуй максимально подробно. Если ты можешь без проблем написать реализацию какого-то блока - значит, ты понял, из чего он состоит. И наоборот, если ты не видишь необходимости расписывать какое-либо действие более подробно - значит, ты понял этот кусок. Как-то так. В твоем случае логика такова: в основной программе перебираем поэлементно массив и для каждого элемента вызываем метод проверки.
1
|
0 / 0 / 0
Регистрация: 06.11.2012
Сообщений: 5
|
|
09.11.2012, 17:56 [ТС] | 3 |
Спасибо за советы. Я пытался сделать универсальное решение, а получилась какая-то сборная солянка. Попробую еще раз, ориентируясь вашим ценным советам. После прочтения Вашего ответа, появились некоторые ценные мысли.
0
|
Master of Orion
|
|
09.11.2012, 20:05 | 4 |
smth, а если внезапно надо будет учитывать не только соседние точки, но и точки через них (то есть не только точки, окаймляющие фигуру "морского боя", но и точки, окаймляющие это окаймовку), то дописывать еще 100500 условий? Автор все правильно делал, а вы его только путаете.
Jabrobaka, С другой стороны, идея более-менее, а вот реализация хромает: куча лишних переменных, к тому же нет смысла использовать sbyte, переменная все равно занимает число байт, кратное четырем, если только она не является полем класса/структуры (так называемое выравнивание). Напишите, чего вы хотите (в чем именно заключается условие локального минимума), мб найдем чем помочь.
1
|
0 / 0 / 0
Регистрация: 06.11.2012
Сообщений: 5
|
|
09.11.2012, 22:12 [ТС] | 5 |
сбайт делал потому, что в паре мест было отрицательное значение -1, не помню уже где, решил все байты в сбайты сделать, чтобы ошибок не было. Переборщил, конечно.
А моя каша получилась как раз из похожих Ваших мыслей, которые Вы изложили в ответе к smth. Нужно решить задачу: "Дана матрица размера M x N. Элемент называется локальным минимумом, если он меньше всех окружающих его элементов. Заменить все локальные минимумы данной матрицы на 0."
0
|
Master of Orion
|
||||||
09.11.2012, 22:38 | 6 | |||||
Jabrobaka, ну например так:
1
|
0 / 0 / 0
Регистрация: 06.11.2012
Сообщений: 5
|
||||||
09.11.2012, 22:45 [ТС] | 7 | |||||
0
|
Master of Orion
|
|
09.11.2012, 22:49 | 8 |
Jabrobaka, почитайте про обобщенные классы и методы:
http://msdn.microsoft.com/ru-r... aeb7t.aspx Добавлено через 1 минуту http://msdn.microsoft.com/ru-r... a29h6.aspx
1
|
09.11.2012, 22:49 | |
09.11.2012, 22:49 | |
Помогаю со студенческими работами здесь
8
Организация поиска в списке. Исправить ошибку в методе поиска Написать процедуру, которая находит номер k последнего локального минимума в массиве вещественных чисел Найти номер первого локального минимума массива Найти номер первого локального минимума массива Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |