Модераторы: javastic
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Перебор всех значений двумерного массива 
:(
    Опции темы
photozaz
Дата 29.9.2014, 12:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 25
Регистрация: 6.5.2008

Репутация: нет
Всего: нет



Добрый день. Есть задача написать процедуру на вход которой будет подаваться двумерный массив рандомной размерности. Требуется вывести все возможные суммы элементов с условием что за одну итерацию из одномерного массива(строки) берется только одно значение. Сам алгоритм выглядит следующим образом. 

Пример:

на входе:
123
456
789

на выходе:
1+4+7 1+4+8 1+4+9
1+5+7 1+5+8 1+5+9
1+6+7 1+6+8 1+6+9

2+4+7 2+4+8 2+4+9
2+5+7 2+5+8 2+5+9
2+6+7 2+6+8 2+6+9

3+4+7 3+4+8 3+4+9
3+5+7 3+5+8 3+5+9
3+6+7 3+6+8 3+6+9

Вопрос: как реализовать данный алгоритм для массива nxn(array [n][n])?
PM MAIL   Вверх
math64
Дата 1.10.2014, 07:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2505
Регистрация: 12.4.2007

Репутация: 1
Всего: 72



Стек + Рекурсия.
В стеке лежат выбранные элементы предыдущих строк массива.
В рекурсивной функции цикл по текущей стоке, помещение выбранного элемента в стек, рекурсивный вызов для следующей строки или вывод результата.
Учти, что каждая строка может иметь свою разменость:
Например, Вход:
1 2
3 4 5
6 7 8 9
PM   Вверх
asd
Дата 1.10.2014, 08:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 89
Регистрация: 25.6.2006

Репутация: нет
Всего: 1



Использование рекурсии применительно к данным неизвестной размерности приводит к переполнению стека, как правило.
PM MAIL   Вверх
math64
Дата 1.10.2014, 12:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2505
Регистрация: 12.4.2007

Репутация: 1
Всего: 72



Ну можно обойтись без рекурсии, если складывать все необходимые данные стек (я имею ввиду java.util.Stack). Будет хитровывернутый цикл, с continue и break, для начала надо написать с рекурсией, а затем оптимизировать.
PM   Вверх
asd
Дата 2.10.2014, 07:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 89
Регистрация: 25.6.2006

Репутация: нет
Всего: 1



Кстати, пришёл в голову очень простой способ получить желаемое:
Код

for (int i = 0; i < n*n; i++){
    String result;
    int currPos = i;
    for (int row = 0; row < n; row++){
        int idx = currPos % n;
        currPos = currPos / n;
        result += array[row][idx];
    }
    Log.d("msg", result);
}


Правда очень много делений. Можно сделать используя только сложение, но тогда понадобится доп array[n] памяти
PM MAIL   Вверх
math64
Дата 2.10.2014, 08:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2505
Регистрация: 12.4.2007

Репутация: 1
Всего: 72



Но не n*n, а n в степени n.
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Android | Следующая тема »


 




[ Время генерации скрипта: 0.0689 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.