Условие задачи | | Прогресс |
Темы:
Рекурсия
Динамическое программирование
Перебор
Перебор с возвратом
Дано число n . Вам необходимо сгенерировать все правильные скобочные последовательности, содержащие n пар скобок.
Входные данные
В первой строке дано натуральное число n (1 <= n <= 8).
Выходные данные
Выведите все правильные скобочные последовательности по возрастанию в лексикографическом порядке. Каждую в отдельной строке.
| |
|
Темы:
Рекурсивный перебор
Перебор с возвратом
Рекурсия
XOR -c умма массива определяется как побитовое XOR всех его элементов или 0 , если массив пуст.
Например, XOR -сумма массива [2,5,6] равна 2 XOR 5 XOR 6 = 1.
Для заданного массива nums , верните сумму всех XOR -сумм для каждого подмножества nums .
Примечание: подмножества, состоящие из одинаковых элементов, считаются различными и должны подсчитываться несколько раз.
Массив a является подмножеством массива b , если a может быть получено из b путем удаления некоторых (возможно не удалением никаких) элементов b .
Входные данные
Программа получает на вход в первой строке натуральное число n - количество элементов массива nums . Во второй строке записаны n чисел numsi .
Ограничения
1 <= n <= 12
1 <= numsi <= 20
Выходные данные
Выведите ответ на задачу.
Пояснения к тестовым примерам
В первом примере
В [1,3] существует 4 подмножества:
- Пустое подмножество имеет XOR-сумму 0.
- [1] имеет XOR-сумму, равную 1.
- [3] имеет XOR-сумму, равную 3.
- В [1,3] сумма XOR равна 1 XOR 3 = 2.
0 + 1 + 3 + 2 = 6
Во втором примере
В [5,1,6] 8 подмножеств:
- Пустое подмножество имеет XOR-сумму 0.
- [5] имеет XOR-сумму, равную 5.
- [1] имеет XOR-сумму, равную 1.
- [6] имеет XOR-сумму, равную 6.
- [5,1] имеет XOR-сумму 5 XOR 1 = 4.
- [5,6] имеет XOR-сумму 5 XOR 6 = 3.
- [1,6] имеет XOR-сумму 1 XOR 6 = 7.
- [5,1,6] имеет XOR-сумму 5 XOR 1 XOR 6 = 2.
0 + 5 + 1 + 6 + 4 + 3 + 7 + 2 = 28
| |
|
Темы:
Рекурсивный перебор
Рекурсия
Перебор с возвратом
Даны два целых числа n и k , выведите все возможные комбинации из k чисел, выбранных из диапазона [1, n] . Порядок элементов в одной комбинации не важен. То есть комбинация (1, 2, 3) и (3, 2, 1) считается одинаковой.
Выведите на экран все такие комбинации в лексикографическом порядке.
Входные данные
В первой строке записано целое число n, во второй - целое число k.
Ограничения
Выходные данные
Выведите в лексикографическом порядке все возможные комбинации из k чисел, выбранных из диапазона [1, n] . Каждая комбинация чисел должна выводиться в отдельной строке, числа в одной комбинации разделяются одним пробелом.
| |
|
Темы:
Перестановки
Рекурсивный перебор
Перебор с возвратом
Вам необходимо выполнить n различных работ. При этом у вас есть список из n разнорабочих и цены, за сколько долларов какой рабочий какую работу выполняет.
Распределите рабочих так, чтобы потратить суммарно меньше денег. При этом вы хотите сделать все дела за один день, поэтому рабочие будут работать параллельно. Таким образом, каждый рабочий будет выполнять ровно одно задание.
Входные данные
В первой строке вам дано положительное число n (1 <= n <= 8) - количество работ и рабочих.
В следующих n строках дано по n положительных чисел, разделенных пробелами - матрица А, где Ai,j показывает за сколько долларов рабочий под номером i выполнит работу под номером j. Для всех Ai,j выполнено 1 <= Ai,j <= 105.
Выходные данные
Выведите одно число - минимальную стоимость, за которую вы можете нанять данных рабочих на все имющиеся дела.
Пояснение к примеру
Первый рабочий выполнит вторую работу, второй рабочий третью работу и третий рабочий первую работу. Итоговая стоимость 1 + 4 + 7 = 12.
| |
|
Темы:
Перестановки
Рекурсивный перебор
Перебор с возвратом
Вам дано натуральное число n . Выведите все перестановки размера n в лексикографическом порядке.
Входные данные
В первой строке дано натуральное число n (1 <= n <= 7).
Выходные данные
Выведите все перестановки по возрастанию в лексикографическом порядке. Каждую в отдельной строке. Числа в перестановке должны быть отделены пробелами.
| |
|
Темы:
Гамильтонов цикл
Гамильтонов цикл
Простые задачи на перебор
Перестановки
Рекурсивный перебор
Перебор с возвратом
Его Величество Король Бубей Второй пожелал объехать свои владения. При этом к маршруту есть следующие пожелания:
1) маршрут должен занимать наименьшее возможное время (королевское время – вещь очень ценная и его надо беречь);
2) маршрут должен включать все населенные пункты ровно по одному разу (если король пропустит какой-то населенный пункт, то его жители будут возмущены королевским невниманием и перестанут платить налоги; если король посетит какой-то населенный пункт больше одного раза, то жители остальных населенных пунктов также возмутятся)
3) маршрут должен начинаться и заканчиваться в столице государства (объехав свои владения, король должен сразу приступить к делам). Столица входит в маршрут ровно 2 раза: как пункт отбытия и как пункт назначения, она не может являться промежуточным населенным пунктом маршрута.
Напишите программу, которая по схеме дорог королевства находит такой маршрут или определяет, что выполнить все требования невозможно.
Входные данные
Сначала вводится число N (натуральное, не превышает 10) – количество населенных пунктов королевства. Затем следует N строк по N чисел в каждой – время пути между населенными пунктами (время – целое неотрицательное число, не превышает 500; если время = 0, то это означает, что пути между какими-то населенными пунктами нет). Населенный пункт №1 является столицей государства.
Выходные данные
Выведите наименьшее суммарное время, которое Его Величество потратит на объезд своих владений, или число -1, если построить маршрут с заданными свойствами невозможно.
| |
|
Темы:
Рекурсия
Перебор с возвратом
Рассмотрим все представления числа \(n\) в виде суммы различных целых возрастающих слагаемых: \(n = a_1 + a_2 + \ldots + a_k\), \(a_1 < a_2 < \ldots < a_k\).
Будем называть такое разбиение быстро возрастающим, если для него выполнено следующее условие: для любых трех подряд идущих слагаемых разница между большим и средним строго больше, чем между средним и меньшим, иначе говоря, \(a_{i+2} - a_{i+1} > a_{i+1} - a_i\).
Задано число \(n\). Выведите все его быстро возрастающие разбиения на слагаемые.
Формат входных данных
На ввод подается целое число \(n\) (\(1 \le n \le 100\)).
Формат выходных данных
Выведите все быстро возрастающие разбиения на слагаемые числа \(n\). Разбиения можно выводить в любом порядке. Выводите слагаемые в каждом разбиении, разделяя их знаком <<+ >> без пробелов.
| |
|