Предыдущая тема :: Следующая тема |
Автор |
Сообщение |
mkmv
Зарегистрирован: 15.12.2005 Сообщения: 2
|
Добавлено: Чт Дек 15 2005 11:31 Заголовок сообщения: Алгоритм поиска максимального числа в n-мерном массиве |
|
|
Собственно сабж. Нужен алгоритм, а за реализацией не постоит
Уточнение вопроса: есть ли универсальный алгоритм поиска например в 3-х или 4-х мерном массиве. Т.е. в зависимости от заданной размерности. |
|
Вернуться к началу |
|
|
September
Зарегистрирован: 14.11.2004 Сообщения: 109 Откуда: Saint-Petersburg
|
Добавлено: Пт Дек 16 2005 18:18 Заголовок сообщения: |
|
|
Да нету тут никакого алгоритма, ИМХО.
В любом случае надо проверять весь массив.
Или вопрос в том, как на одинаковом коде проверить одномерный массив, матрицу или n-мерный? |
|
Вернуться к началу |
|
|
mkmv
Зарегистрирован: 15.12.2005 Сообщения: 2
|
Добавлено: Сб Дек 17 2005 22:07 Заголовок сообщения: |
|
|
именно. т.е. чтобы лишнего ничего не написать хороший такой алгоритм обрабтки от 1-но мерного до 4-х. |
|
Вернуться к началу |
|
|
September
Зарегистрирован: 14.11.2004 Сообщения: 109 Откуда: Saint-Petersburg
|
Добавлено: Сб Дек 17 2005 22:45 Заголовок сообщения: |
|
|
Повторюсь, здесь нет алгоритма. Нужен перебор всех элементов массива.
А по коду:
Что есть массив?
Точнее, что есть:
int a[2][2][2] = ...;
На самом деле a в данном случае указывает на начало "куска" выделенной под массив памяти.
Забывая о том, что мы работаем в х-мерным массивом и перечитав определение выше, приходим к тому, что a указывает на одномерный массив размером 8 элементов.
Нужен код? ИМХО, в С пройдет
int *a[][][] = ....
a++ => получение следующего элемента.
В Java не смогу сказать точно, нужно читать спецификацию.
Не хочу писать код - ИМХО, человек должен сам попробовать что-то
сделать, тогда сможет решать аналогичные проблемы.
Если что-то не понятно, то спрашивайте - по теории отвечу, по коду могу предложить только STFW - примеры есть в книгах о С точно. |
|
Вернуться к началу |
|
|
Aragaer
Зарегистрирован: 28.03.2005 Сообщения: 164
|
Добавлено: Вс Дек 18 2005 08:50 Заголовок сообщения: |
|
|
Проблема.
Даже в С трехмерный массив это на самом деле массив указателей на двумерные, каждый из которых в свою очередь - массив указателей... Вся эта ерунда может быть раскидана по памяти как угодно.
Остается только вариант с честным вкладыванием нужного числа циклов друг в друга. Но поскольку нужен этакий общий алгоритм... Нам не зря дана рекурсия:
Код: | int FindMax(int *array, int depth) {
int maxval = 0;
for (int i=0; i < nElements(array); i++)
maxval = max(maxval, depth ? FindMax(array[i], depth-1) : array[i]);
return maxval
} | В общих чертах примерно так. Подпрограмму max и макрос nElements я приводить не стану, можно и без них вообще.
Теперь чтобы найти наибольший элемент в N-мерном массиве, выполняем FindMax(array, N-1); Вуаля. _________________ Open your eyes.
And Awaken. |
|
Вернуться к началу |
|
|
|