Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Алгоритм поиска максимального числа в n-мерном массиве

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
mkmv



Зарегистрирован: 15.12.2005
Сообщения: 2

СообщениеДобавлено: Чт Дек 15 2005 11:31    Заголовок сообщения: Алгоритм поиска максимального числа в n-мерном массиве Ответить с цитатой

Собственно сабж. Нужен алгоритм, а за реализацией не постоит Wink
Уточнение вопроса: есть ли универсальный алгоритм поиска например в 3-х или 4-х мерном массиве. Т.е. в зависимости от заданной размерности.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
September



Зарегистрирован: 14.11.2004
Сообщения: 109
Откуда: Saint-Petersburg

СообщениеДобавлено: Пт Дек 16 2005 18:18    Заголовок сообщения: Ответить с цитатой

Да нету тут никакого алгоритма, ИМХО.
В любом случае надо проверять весь массив.

Или вопрос в том, как на одинаковом коде проверить одномерный массив, матрицу или n-мерный?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение AIM Address Yahoo Messenger MSN Messenger
mkmv



Зарегистрирован: 15.12.2005
Сообщения: 2

СообщениеДобавлено: Сб Дек 17 2005 22:07    Заголовок сообщения: Ответить с цитатой

именно. т.е. чтобы лишнего ничего не написать Wink хороший такой алгоритм обрабтки от 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 - примеры есть в книгах о С точно.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение AIM Address Yahoo Messenger MSN Messenger
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.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...