Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 32, средняя оценка - 4.81
vortexx1
6 / 6 / 2
Регистрация: 06.03.2011
Сообщений: 269
#1

Полный перебор - C++

21.10.2012, 11:57. Просмотров 5227. Ответов 7
Метки нет (Все метки)

Здравствуйте. Скорее всего, я пришел не по адресу и мне следовало бы задать свой вопрос где-нибудь в разделе алгоритмов, но не суть. Я всё еще верю в алгоритмическую подготовку кресторебятушек.

В общем, суть такая: успешно провалив очередной раунд Codeforces, я внезапно осознал, что не умею делать полный перебор. Такой, чтоб прямо полнейший. То есть, если требуются все возможные перестановки трёх чисел от 0 до 1, получить
0 0 0
0 0 1
0 1 0
1 0 0
0 1 1
1 1 0
1 1 1

Вообще я слышу запах рекурсии, но что-то пока не особо как-то. Может в стандартной библиотеке есть что-то такое, что я проглядел? Хотел извращаться с std::next_permutation, но медленно и не то.

Заранее спасибо.
С меня как всегда.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.10.2012, 11:57
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Полный перебор (C++):

Полный перебор - C++
Дано множество целых чисел. Требуется разбить множество на две части суммы элементов которых равны. Если нельзя провести разбиение, выдать...

Полный перебор чисел массива - C++
Доброго вам времени суток. Количество элементов массива задавать вручную - собственно N. Массив заполняется числами от 1 до N. Стоит...

Методы поиска: полный перебор и интерполяционный - C++
Найти самолет, вылетающий в 1400. Методы поиска: полный перебор и интерполяционный. как это в массиве записать?

Все возможные комбинации пароля. Метод грубой силы (полный перебор) - C++
Вопрос собственно заключается в том, почему при выводе в консоль всех возможных комбинаций пароля, пишет непонятные символы,как показано на...

Полный дек - C++
Добрый день! мучаюсь с задачей - реализовать тип и функции (инициализация,добавление\извлечение элементов с обеих сторон,проверка на...

Учебник по C++ полный. - C++
Где взять такой учебник где все рассказывается о языке от а до я???

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
21.10.2012, 12:20 #2
Цитата Сообщение от vortexx1 Посмотреть сообщение
То есть, если требуются все возможные перестановки трёх чисел от 0 до 1, получить
0 0 0
0 0 1
0 1 0
1 0 0
0 1 1
1 1 0
1 1 1
Но это же не перестановки, а размещение с повторениями.

Добавлено через 8 минут
к тому же потерялась комбинация 1 0 1
1
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
21.10.2012, 12:25 #3
Это ж не перестановки, это комбинации.

Конкретно для данного случая, чем не угодил тупой как кирпич вариант?
C++
1
2
3
4
5
for (int i = 0; i < 1; ++i)
    for (int j = 0; j < 1; ++j)
        for (int k = 0; k < 1; ++k) {
            // std::cout << i << " " << j << " " << k << "\n";
        }
Если там надо произвольное количество таких чисел, то уже придётся извращаться и писать что-то вроде
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
{   std::vector<unsigned> nums(3, 0); // понимать как вектор цифр числа в какой-то системе счисления
    bool over = false;
    while (!over) {
/*
        for (int i = 0, len = nums.size(); i < len; ++i) {
            std::cout << nums[i] << " ";
        }
        std::cout << "\n";
*/
        over = next_count(nums, 2); // получить следующее число в двоичной системе
    }
}
 
// Функция add() из любой библиотечки длинной арифметики
bool next_count(std::vector<unsigned> &vec, unsigned base)
{
    bool carry = true;
    for (int i = 0, len = vec.size(); i < len; ++i) {
        if (carry) {
            vec[i]++;
            carry = false;
        }
        if (vec[i] >= base) {
            vec[i] -= base;
            carry = true;
        }
    }
    return carry; // carry == произошло ли переполнение
}
2
Thinker
Эксперт C++
4225 / 2199 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
21.10.2012, 12:44 #4
такие алгоритмы через рекурсию очень удобно записывать
0
Kastaneda
Форумчанин
Эксперт С++
4653 / 2862 / 228
Регистрация: 12.12.2009
Сообщений: 7,271
Записей в блоге: 2
Завершенные тесты: 1
21.10.2012, 12:48 #5
Конкретно для данного случая можно сделать так
C++
1
2
3
4
for (int i = 0; i < 8; i++)
{
    std::cout << octToBin(i) << std::endl;
}
0
vortexx1
6 / 6 / 2
Регистрация: 06.03.2011
Сообщений: 269
21.10.2012, 13:13  [ТС] #6
Нужно для общего случая, с любым количество элементов, в любом диапазоне.
0
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
21.10.2012, 13:21 #7
Ну я, например, так делал:
Генератор слов для телефонного номера
1
Thinker
Эксперт C++
4225 / 2199 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
21.10.2012, 13:47 #8
если элементы 0 и 1, то очень удобно с битами работать:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void DisplayBits(int a, int n)
{
    int i;
    for (i = n - 1; i >= 0; i--)
       printf("%d ", ((a >> i) & 1));
    printf("\n");
}
 
 
int main()
{
    int n = 5, i, size;
    size = 1 << n;
    for(i = 0; i < size; i++)
       DisplayBits(i, n);
    return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.10.2012, 13:47
Привет! Вот еще темы с ответами:

Полный учебник с++ - C++
Доброго времени суток!!! Ситуация такая: изучил основы c++, хочу изучить ПОЛНОСТЬЮ его. Подскажите, пожалуйста, учебник на русском,...

Перебор - C++
Ребят, помогите решить две задачи. Занимаюсь программированием уже 6 лет. Но тут в ступор встал. 1 задача: есть массив. из него нужно...

Перебор - C++
Hi.мне нужно часть кода в котором перебирает все значение пример у нас 2 банки(на много литров),и 10 л воды.Нужно сделать все возможние...

Полный разбор JPEG в С++ - C++
Товарищи!!!! Огромная проблема по учебе, требуется ваша помощь, весь инет уже перелазил Необходимо открыть JPEG файл в С++, но просто...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
21.10.2012, 13:47
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru