самый быстрый способ (раз упорядоченный список):
nums = [1, 2, 2, 3, 4, 5, 5, 5]
count = 1
for i in range(1, len(nums)):
if nums[i - 1] != nums[i]:
count += 1
print(count)
или чуть сократив код:
count = 1
for i in range(1, len(nums)):
count += nums[i - 1] != nums[i]
правда стоит сделать проверку для ситуации, когда список пустой
из той же серии (если требуется не только подсчитать кол-во элементов, но и найти эти элементы)
count = len([nums[0]] + [nums[i] for i in range(1, len(nums)) if nums[i - 1] != nums[i]])
Это все требует одного прохода по списку
Можно написать очень короткий код, но по времени работы для такой задачи он будет неоптимальным
count = len(set(nums))
Самый неоптимальный по времени работы код
nums = [1, 2, 2, 3, 4, 5, 5, 5]
res = []
for elem in nums:
if elem not in res:
res.append(elem)
print(len(res))
01: Количество различных чисел
Дан список чисел, который могут содержать до 100000 чисел каждый.
Определите, сколько в нем встречается различных чисел.
Ввод | Вывод |
---|---|
1 2 3 2 1 |
3 |
Примечание. Эту задачу на Питоне можно решить в одну строчку.
Решение
print(len(set(input().split())))
02: Количество совпадающих
Даны два списка чисел, которые могут содержать до 100000 чисел каждый.
Посчитайте, сколько чисел содержится одновременно как в первом списке, так и во втором.
Ввод | Вывод |
---|---|
1 2 3 |
2 |
Примечание. Эту задачу на Питоне можно решить в одну строчку.
Решение
print(len(set(input().split()) & set(input().split())))
03: Пересечение списков
Даны два списка чисел, которые могут содержать до 10000 чисел каждый.
Выведите все числа, которые входят как в первый, так и во второй список в порядке возрастания.
Ввод | Вывод |
---|---|
1 2 3 |
2 3 |
Примечание. И даже эту задачу на Питоне можно решить в одну строчку.
Решение
print(' '.join(map(str, sorted(map(int, list(set(input().split()) & set(input().split())))))))
04: Встречалось ли число раньше
Во входной строке записана последовательность чисел через пробел.
Для каждого числа выведите слово YES
(в отдельной строке),
если это число ранее встречалось в последовательности или NO
,
если не встречалось.
Ввод | Вывод |
---|---|
1 2 3 2 3 4 |
NO |
Решение
data = input().split() cur_set = set() for item in data: if item in cur_set: print('YES') else: print('NO') cur_set.add(item)
05: Кубики
Аня и Боря любят играть в разноцветные кубики, причем у каждого из них свой
набор и в каждом наборе все кубики различны по цвету. Однажды дети заинтересовались,
сколько существуют цветов таких, что кубики каждого цвета присутствуют в обоих
наборах. Для этого они занумеровали все цвета случайными числами. На этом их энтузиазм
иссяк, поэтому вам предлагается помочь им в оставшейся части.
Номер любого цвета — это целое число в пределах от 0 до 109.
В первой строке входного файла записаны числа N и M — количество кубиков у Ани и Бори
соответственно. В следующих N строках заданы номера цветов кубиков Ани. В
последних M строках номера цветов кубиков Бори.
Выведите сначала количество, а затем отсортированные по возрастанию номера цветов
таких, что кубики каждого цвета есть в обоих наборах, затем количество
и отсортированные по возрастанию номера остальных цветов у Ани, потом количество и
отсортированные по возрастанию номера остальных цветов у Бори.
Ввод | Вывод |
---|---|
4 3 |
2 |
Решение
num_anna_cubes, num_boris_cubes = map(int, input().split()) anna = {input() for i in range(num_anna_cubes)} boris = {input() for i in range(num_boris_cubes)} both_cubes = anna & boris anna_only_cubes = anna - both_cubes boris_only_cubes = boris - both_cubes print(len(both_cubes)) print(' '.join(sorted(both_cubes, key=int))) print(len(anna_only_cubes)) print(' '.join(sorted(anna_only_cubes, key=int))) print(len(boris_only_cubes)) print(' '.join(sorted(boris_only_cubes, key=int)))
06: Количество слов в тексте
Во входном файле (вы можете читать данные из файла input.txt
)
записан текст. Словом считается последовательность непробельных символов
идущих подряд, слова разделены одним или большим числом пробелов
или символами конца строки.
Определите, сколько различных слов содержится в этом тексте.
Ввод | Вывод |
---|---|
She sells sea shells on the sea shore; |
19 |
Решение
print(len(set(open('input.txt').read().split())))
07: Угадай число
Август и Беатриса играют в игру. Август загадал натуральное число от 1 до n. Беатриса пытается
угадать это число, для этого она называет некоторые множества натуральных чисел. Август отвечает
Беатрисе YES
, если среди названных ей чисел есть задуманное или NO
в противном случае. После нескольких заданныъх вопросов Беатриса запуталась в том, какие вопросы
она задавала и какие ответы получила и просит вас помочь ей определить, какие числа мог задумать Август.
Первая строка входных данных содержит число n — наибольшее число, которое мог загадать
Август. Далее идут строки, содержащие вопросы Беатрисы. Каждая строка представляет собой набор чисел, разделенных
пробелами. После каждой строки с вопросом идет ответ Августа: YES
или NO
.
Наконец, последняя строка входных данных содержит одно слово HELP
. Вы должны вывести (через пробел,
в порядке возрастания) все числа, которые мог задумать Август.
Ввод | Вывод |
---|---|
10 |
1 3 5 |
Решение
max_august_number = int(input()) possible_numbers = {str(i) for i in range(1, max_august_number + 1)} s_not_in = set() while True: numbers_or_help = input() if numbers_or_help == 'HELP': break cur_set = set(numbers_or_help.split()) yes_or_no = input() if yes_or_no == 'YES': possible_numbers &= cur_set elif yes_or_no == 'NO': possible_numbers -= cur_set print(' '.join(sorted(possible_numbers, key=int)))
08: Угадай число – 2
Август и Беатриса продолжают играть в игру, но Август начал жульничать.
На каждый из вопросов Беатрисы он выбирает такой вариант ответа YES
или NO
,
чтобы множество возможных задуманных чисел оставалось как можно больше. Например,
если Август задумал число от 1 до 5, а Беатриса спросила про числа 1 и 2, то Август
ответит NO
, а если Беатриса спросит про 1, 2, 3, то Август ответит YES
.
Если же Бетриса в своем вопросе перечисляет ровно половину из задуманных чисел, то Август
из вредности всегда отвечает NO
.
Наконец, Август при ответе учитывает все предыдущие вопросы Беатрисы и свои ответы на них,
то есть множество возможных задуманных чисел уменьшается.
Вам дана последовательность вопросов Беатрисы. Приведите ответы Августа на них.
Первая строка входных данных содержит число n — наибольшее число, которое мог загадать
Август. Далее идут строки, содержащие вопросы Беатрисы. Каждая строка представляет собой набор чисел, разделенных
пробелами. Последняя строка входных данных содержит одно слово HELP
.
Для каждого вопроса Беатрисы выведите ответ Августа на этот вопрос. После этого выведите
(через пробел, в порядке возрастания) все числа, которые мог загадать Август после ответа на все
вопросы Беатрисы.
Ввод | Вывод |
---|---|
10 |
NO |
Решение
max_august_number = int(input()) possible_numbers = {str(i) for i in range(1, max_august_number + 1)} numbers_or_help = input() while numbers_or_help and numbers_or_help != 'HELP': cur_set = set(numbers_or_help.split()) if len(cur_set & possible_numbers) * 2 > len(possible_numbers): print('YES') possible_numbers &= cur_set else: print('NO') possible_numbers -= cur_set numbers_or_help = input() print(' '.join(sorted(possible_numbers, key=int)))
09: Полиглоты
Каждый из (N) школьников некоторой школы знает (M_i) языков.
Определите, какие языки знают все школьники и языки, которые знает
хотя бы один из школьников.
Первая строка входных данных содержит количество школьников (N).
Далее идет (N) чисел (M_i), после каждого из чисел идет (M_i) строк,
содержищих названия языков, которые
знает (i)-й школьник. Длина названий языков не превышает 1000 символов, количество
различных языков не более 1000. (1 le N le 1000), (1 le M_i le 500).
Ввод | Вывод |
---|---|
3 |
1 |
Решение
num_pupils = int(input()) lang_union = set() lang_intersect = set() for i in range(num_pupils): num_cur_lang = int(input()) cur_set = {input() for j in range(num_cur_lang)} if i != 0: lang_union &= cur_set else: lang_union = cur_set lang_intersect |= cur_set print(len(lang_union)) print('n'.join(lang_union)) print(len(lang_intersect)) print('n'.join(lang_intersect))
10: Забастовки
Политическая жизнь одной страны очень оживленная. В стране действует K политических партий,
каждая из которых регулярно объявляет национальную забастовку. Дни, когда хотя бы
одна из партий объявляет забастовку, при условии, что это не суббота или воскресенье
(когда и так никто не работает), наносят большой ущерб экономике страны.
(i)-я партия объявляет забастовки строго каждые (b_i) дней, начиная с
дня с номером (a_i). То есть (i)-я партия объявляет забастовки в дни
(a_i), (a_i+b_i), (a_i+2b_i) и т.д. Если в какой-то день несколько
партий объявляет забастовку, то это считается одной общенациональной забастовкой.
В календаре страны (N) дней, пронумерованных от (1) до (N). Первый день
года является понедельником, шестой и седьмой дни недели — выходные,
неделя состоит из семи дней.
Программа получает на вход число дней в году (N) ((1le Nle10^6)) и число политических
партий (K) ((1le Kle100)). Далее идет (K) строк, описывающие графики проведения забастовок.
(i)-я строка содержит числа (a_i) и (b_i)
((1le a_i, b_ile N)).
Выведите единственное число: количество забастовок, произошедших в течение года.
Ввод | Вывод |
---|---|
19 3 |
8 |
Примечание. Первая партия объявляет забастовки в дни 2, 5, 8, 11, 14, 17.
Вторая партия объявляет забастовки в дни 3, 8, 13, 18. Третья партия —
в дни 9 и 17. Дни номер 6, 7, 13, 14 являются выходными. Таким образом,
общенациональные забастовки пройдут в дни 2, 3, 5, 8, 9, 11, 17, 18.
Решение
days_in_calendar, num_parties = map(int, input().split()) new_N = days_in_calendar all_strikes = set() for i in range(num_parties): cur_start, cur_step = map(int, input().split()) cur_strikes = set(i for i in range(cur_start, new_N + 1, cur_step)) if cur_step == 1: # speed-up hack new_N = cur_start all_strikes |= cur_strikes all_strikes -= set(i for i in range(6, days_in_calendar + 1, 7)) all_strikes -= set(i for i in range(7, days_in_calendar + 1, 7)) print(len(all_strikes))
11: Номер появления слова
Во входном файле (вы можете читать данные из файла input.txt
)
записан текст. Словом считается последовательность непробельных символов
идущих подряд, слова разделены одним или большим числом пробелов
или символами конца строки.
Для каждого слова из этого текста подсчитайте, сколько раз оно встречалось
в этом тексте ранее.
Ввод | Вывод |
---|---|
one two one two three |
0 0 1 1 0 |
She sells sea shells on the sea shore; |
0 0 0 0 0 0 1 0 0 1 0 0 1 0 2 2 0 0 0 0 1 2 3 3 1 1 4 0 1 0 1 2 4 1 5 0 0 |
Решение
word_dict = {} for word in open('input.txt').read().split(): word_dict[word] = word_dict.get(word, -1) + 1 print(word_dict[word], end = ' ')
12: Словарь синонимов
Вам дан словарь, состоящий из пар слов. Каждое слово является синонимом к парному ему слову.
Все слова в словаре различны. Для одного данного слова определите его синоним.
Программа получает на вход словарь синонимов. Каждая строка словаря
содержит два слова, разделенных пробелами.
Далее до конца файла идет последовательность слов (по одному слову в строке).
Программа должна для каждого слова вывести его синоним.
Ввод | Вывод |
---|---|
Hello Hi |
Bye |
Эту задачу можно решить и без словарей (сохранив все входные данные в списке),
но решение со словарем будет более простым.
Решение
data = [line.split() for line in open('input.txt')] synonym_dict = {x[0]: x[1] for x in data if len(x) == 2} synonym_dict.update({x[1]: x[0] for x in data if len(x) == 2}) [print(synonym_dict[y[0]]) for y in data if len(y) == 1]
13: Выборы в США
Как известно, в США президент выбирается не прямым голосованием, а путем двухуровневого голосования.
Сначала проводятся выборы в каждом штате и определяется победитель выборов в данном штате.
Затем проводятся государственные выборы: на этих выборах каждый штат имеет определенное
число голосов — число выборщиков от этого штата. На практике, все выборщики
от штата голосуют в соответствии с результами голосования внутри штата, то есть
на заключительной стадии выборов в голосовании участвуют штаты, имеющие различное число голосов.
Вам известно за кого проголосовал каждый штат и сколько голосов было отдано данным штатом.
Подведите итоги выборов: для каждого из участника голосования определите число отданных за него голосов.
Каждая строка входного файла содержит фамилию кандидата, за которого
отдают голоса выборщики этого штата, затем через пробел идет количество выборщиков,
отдавших голоса за этого кандидата.
Выведите фамилии всех кандидатов в лексикографическом порядке,
затем, через пробел, количество отданных за них голосов.
Ввод | Вывод |
---|---|
McCain 10 |
McCain 16 |
Ivanov 1 |
Ivanov 1 |
Решение
input = open('input.txt') elections_dict = dict() for line in input: candidate, votes = line.split() elections_dict[candidate] = elections_dict.get(candidate, 0) + int(votes) for candidate, votes in sorted(elections_dict.items()): print(candidate, votes) input.close()
14: Самое частое слово
Дан текст. Выведите слово, которое в этом тексте встречается чаще всего.
Если таких слов несколько, выведите то, которое меньше в лексикографическом
порядке.
Ввод | Вывод |
---|---|
apple orange banana banana orange |
banana |
Решение
all_words = open('input.txt').read().split() num_words_dict = dict() for word in all_words: num_words_dict[word] = num_words_dict.get(word, 0) + 1 most_frequent = min(list(num_words_dict.items()), key=lambda _: (-_[1], _[0])) print(most_frequent[0])
15: Права доступа
В файловую систему одного суперкомпьютера проник вирус,
который сломал контроль за правами доступа к файлам. Для каждого файла (N_i) известно,
с какими действиями можно к нему обращаться:
- запись
W
, - чтение
R
, - запуск
X
.
Вам требуется восстановить контроль над правами доступа к файлам
(ваша программа для каждого запроса должна будет возвращать OK
если над файлом выполняется допустимая операция, или же
Access denied
, если операция недопустима.
В первой строке входного файла содержится число (N)
((1 le N le 10000)) —количество файлов содержащихся в данной файловой системе.
В следующих (N) строчках содержатся имена файлов и допустимых с ними операций,
разделенные пробелами. Длина имени файла не превышает 15 символов.
Далее указано чиcло (M) ((1 le M le 50000)) — количество запросов к файлам.
В последних (M) строках указан запрос вида Операция Файл
.
К одному и тому же файлу может быть применено любое колличество запросов.
Для каждого из (M) запросов нужно вывести в отдельной строке
Access denied
или OK
.
Ввод | Вывод |
---|---|
4 |
OK |
Решение
num_files = int(input()) files_permis = {} for i in range(num_files): filename, *permissions = input().split() files_permis[filename] = {'read': 'R' in permissions, 'write': 'W' in permissions, 'execute': 'X' in permissions} num_tests = int(input()) for i in range(num_tests): operation, filename = input().split() if files_permis[filename][operation]: print('OK') else: print('Access denied')
16: Частотный анализ
Дан текст. Выведите все слова, встречающиеся в тексте, по одному на каждую строку.
Слова должны быть отсортированы по убыванию их количества появления в тексте,
а при одинаковой частоте появления — в лексикографическом порядке.
Ввод | Вывод |
---|---|
hi |
damme |
Указание. После того, как вы создадите словарь всех слов, вам захочется отсортировать
его по частоте встречаемости слова. Желаемого можно добиться, если создать список,
элементами которого будут кортежи из двух элементов: частота встречаемости слова
и само слово. Например, [(2, 'hi'), (1, 'what'), (3, 'is')]
.
Тогда стандартная сортировка будет сортировать список кортежей, при этом
кортежи сравниваются по первому элементу, а если они равны —
то по второму. Это почти то, что требуется в задаче.
Решение
num_words_dict = dict() for word in open('input.txt').read().split(): num_words_dict[word] = num_words_dict.get(word, 0) + 1 for word, repeats in sorted(list(num_words_dict.items()), key=lambda _: (-_[1], _[0])): print(word)
17: Страны и города
Дан список стран и городов каждой страны. Затем даны названия городов. Для каждого города
укажите, в какой стране он находится.
Программа получает на вход количество стран (N). Далее идет
(N) строк, каждая строка начинается с названия страны, затем идут названия городов
этой страны. В следующей строке записано число (M), далее идут (M) запросов —
названия каких-то (M) городов, перечисленных выше.
Для каждого из запроса выведите название страны, в котором находится данный город.
Ввод | Вывод |
---|---|
2 |
Inca |
Решение
num_countries = int(input()) cities_country = {} for i in range(num_countries): country, *cities = input().split() for city in cities: cities_country[city] = country num_tests = int(input()) for i in range(num_tests): print(cities_country[input()])
18: Банковские счета
Некоторый банк хочет внедрить систему управления счетами клиентов, поддерживающую
следующие операции:
- Пополнение счета клиента.
- Снятие денег со счета.
- Запрос остатка средств на счете.
- Перевод денег между счетами клиентов.
- Начисление процентов всем клиентам.
Вам необходимо реализовать такую систему. Клиенты банка идентифицируются именами (уникальная строка, не содержащая
пробелов). Первоначально у банка нет ни одного клиента. Как только для клиента проводится операция пололнения,
снятия или перевода денег, ему заводится счет с нулевым балансом. Все дальнейшие операции проводятся только
с этим счетом. Сумма на счету может быть как положительной, так и отрицательной, при этом всегда является целым числом.
Входной файл содержит последовательность операций. Возможны следующие операции:
DEPOSIT name sum
– зачислить сумму sum
на счет клиента name
.
Если у клиента нет счета, то счет создается.
WITHDRAW name sum
– снять сумму sum
со счета клиента name
.
Если у клиента нет счета, то счет создается.
BALANCE name
– узнать остаток средств на счету клиента name
.
TRANSFER name1 name2 sum
– перевести сумму sum
со счета клиента name1
на счет клиента name2
. Если у какого-либо клиента нет счета, то ему создается счет.
INCOME p
– начислить всем клиентам, у которых открыты счета, p
%
от суммы счета. Проценты начисляются только клиентам с положительным остатком на счету,
если у клиента остаток отрицательный, то его счет не меняется. После начисления процентов
сумма на счету остается целой, то есть начисляется только целое число денежных единиц.
Дробная часть начисленных процентов отбрасывается.
Для каждого запроса BALANCE
программа должна вывести остаток на счету данного
клиента. Если же у клиента с запрашиваемым именем не открыт счет в банке, выведите
ERROR
.
Ввод | Вывод |
---|---|
DEPOSIT Ivanov 100 |
105 |
Решение
def customer_movement(name, amount): customers[name] = customers.get(name, 0) + amount customers = {} for line in open('input.txt'): command, *data = line.split() if command == 'DEPOSIT': name, amount = data customer_movement(name, int(amount)) elif command == 'WITHDRAW': name, amount = data customer_movement(name, -int(amount)) elif command == 'BALANCE': name = data[0] print(customers.get(name, 'ERROR')) elif command == 'TRANSFER': name1, name2, amount = data customer_movement(name1, -int(amount)) customer_movement(name2, int(amount)) elif command == 'INCOME': p = int(data[0]) for name in customers: if customers[name] > 0: customers[name] += customers[name] * p // 100
19: Англо-латинский словарь
Однажды, разбирая старые книги на чердаке, школьник Вася нашёл англо-латинский словарь.
Английский он к тому времени знал в совершенстве, и его мечтой было изучить латынь.
Поэтому попавшийся словарь был как раз кстати.
К сожалению, для полноценного изучения языка недостаточно только одного словаря: кроме англо-латинского необходим
латинско-английский. За неимением лучшего он решил сделать второй словарь из первого.
Как известно, словарь состоит из переводимых слов, к каждому из которых приводится несколько слов-переводов.
Для каждого латинского слова, встречающегося где-либо в словаре, Вася предлагает найти все его переводы
(то есть все английские слова, для которых наше латинское встречалось в его списке переводов),
и считать их и только их переводами этого латинского слова.
Помогите Васе выполнить работу по созданию латинско-английского словаря из англо-латинского.
В первой строке содержится единственное целое число N — количество английских слов в словаре.
Далее следует N описаний. Каждое описание содержится в отдельной строке, в которой записано сначала
английское слово, затем отделённый пробелами дефис (символ номер 45), затем разделённые запятыми
с пробелами переводы этого английского слова на латинский. Переводы отсортированы в лексикографическом
порядке. Порядок следования английских слов в словаре также лексикографический.
Все слова состоят только из маленьких латинских букв, длина каждого слова не превосходит 15 символов.
Общее количество слов на входе не превышает 100000.
Выведите соответствующий данному латинско-английский словарь, в точности соблюдая формат входных данных.
В частности, первым должен идти перевод лексикографически минимального латинского слова,
далее — второго в этом порядке и т.д. Внутри перевода английские слова должны быть также отсортированы лексикографически.
Ввод | Вывод |
---|---|
3 |
7 |
Решение
num_words = int(input()) latin_to_english_dict = {} for i in range(num_words): line = input() sep = line.find('-') english_word = line[: sep - 1] latin_words = line[sep + 2:].split(', ') for word in latin_words: if word not in latin_to_english_dict: latin_to_english_dict[word] = [english_word] else: latin_to_english_dict[word].append(english_word) print(len(latin_to_english_dict)) for latin_word in sorted(latin_to_english_dict): print(latin_word + ' - ' + ', '.join(sorted(latin_to_english_dict[latin_word])))
20: Контрольная по ударениям
Учительница задала Пете домашнее задание — в заданном тексте расставить ударения в словах,
после чего поручила Васе проверить это домашнее задание. Вася очень плохо знаком с данной темой,
поэтому он нашел словарь, в котором указано, как ставятся ударения в словах. К сожалению,
в этом словаре присутствуют не все слова. Вася решил, что в словах, которых нет в словаре,
он будет считать, что Петя поставил ударения правильно, если в этом слове Петей поставлено ровно одно ударение.
Оказалось, что в некоторых словах ударение может быть поставлено больше, чем одним способом.
Вася решил, что в этом случае если то, как Петя поставил ударение, соответствует одному из приведенных
в словаре вариантов, он будет засчитывать это как правильную расстановку ударения, а если не соответствует, то как ошибку.
Вам дан словарь, которым пользовался Вася и домашнее задание, сданное Петей. Ваша задача — определить количество ошибок,
которое в этом задании насчитает Вася.
Вводится сначала число N — количество слов в словаре (0≤N≤20000).
Далее идет N строк со словами из словаря. Каждое слово состоит не более чем из 30 символов.
Все слова состоят из маленьких и заглавных латинских букв. В каждом слове заглавная ровно одна буква — та,
на которую попадает ударение. Слова в словаре расположены в алфавитном порядке. Если есть несколько возможностей
расстановки ударения в одном и том же слове, то эти варианты в словаре идут в произвольном порядке.
Далее идет упражнение, выполненное Петей. Упражнение представляет собой строку текста, суммарным объемом не более 300000 символов.
Строка состоит из слов, которые разделяются между собой ровно одним пробелом. Длина каждого слова не превышает 30 символов.
Все слова состоят из маленьких и заглавных латинских букв (заглавными обозначены те буквы, над которыми Петя поставил ударение).
Петя мог по ошибке в каком-то слове поставить более одного ударения или не поставить ударения вовсе.
Выведите количество ошибок в Петином тексте, которые найдет Вася.
Ввод | Вывод | Комментарии |
---|---|---|
4 |
2 |
В слове cannot, согласно словарю возможно два варианта расстановки ударения. Эти варианты в словаре могут быть перечислены в любом порядке (т.е. как сначала cAnnot, а потом cannOt, так и наоборот). Две ошибки, совершенные Петей — это слова be (ударение вообще не поставлено) и fouNd (ударение поставлено неверно). Слово thE отсутствует в словаре, но поскольку в нем Петя поставил ровно одно ударение, признается верным. |
4 |
4 |
Неверно расставлены ударения во всех словах, кроме The (оно отсутствует в словаре, в нем поставлено ровно одно ударение). В остальных словах либо ударные все буквы (в слове PAGE), либо не поставлено ни одного ударения. |
Решение
correct_accents = {input() for i in range(int(input()))} known_words = {word.lower() for word in correct_accents} errors = 0 for word in input().split(): if word.lower() not in known_words: errors += (sum(['A' <= c <= 'Z' for c in word]) != 1) else: errors += word not in correct_accents print(errors)
21: Продажи
Дана база данных о продажах некоторого интернет-магазина.
Каждая строка входного файла представляет собой запись вида
Покупатель товар количество
, где
Покупатель
— имя покупателя (строка без пробелов),
товар
— название товара (строка без пробелов),
количество
— количество приобретенных единиц
товара.
Создайте список всех покупателей, а для каждого покупателя
подсчитайте количество приобретенных им единиц каждого вида товаров.
Выведите список всех покупателей в лексикографическом порядке,
после имени каждого покупателя выведите двоеточие,
затем выведите список названий всех приобретенных данным покупателем товаров
в лексикографическом порядке, после названия каждого товара выведите
количество единиц товара, приобретенных данным покупателем.
Информация о каждом товаре выводится в отдельной строке.
Ввод | Вывод |
---|---|
Ivanov paper 10 |
Ivanov: |
Указание. В этой задаче удобно завести словарь, в котором ключом является имя человека, а значением — набор его покупок.
Набор его покупок в свою очередь представляет собой таже словарь, где ключом является название товара,
а значением — его количество. Таким образом, получится словарь, каждый элемент которого также
является словарем.
Решение
names = {} for line in open('input.txt'): name, good, num = line.split() if name not in names: names[name] = {good: int(num)} else: names[name][good] = names[name].get(good, 0) + int(num) for name in sorted(names): print(name + ':') for item in sorted(names[name]): print(item, names[name][item])
22: Выборы в США – 2
На этот раз вам известно число выборщиков от каждого штата США и
результаты голосования каждого гражданина США (а также в каком штате
проживает данный гражданин).
Вам необходимо подвести результаты голосования: сначала определить результаты
голосования в каждом штате и определить, за какого из кандидатов отданы
голоса выборщиков данного штата. Далее необходимо подвести результаты голосования выборщиков по всем штатам.
Первая строка входных данных содержит количество штатов в США N.
Далее идет N строк, описывающих штаты США, каждая строка состоит из
названия штата и числа выборщиков от этого штата. Далее до конца
файла идут записи результатов голосования по каждому из участников
голосования. Одна строка соответствует одному избирателю.
Записи имеют вид: название штата, имя кандидата, за которого проголосовал
данный избиратель. Названия штатов и имена кандидатов не содержат пробелов.
Выведите список кандидатов, упорядоченный по убыванию числа голосов
выборщиков, полученных за данного кандидата, а при равенстве числа голосов
выборщиков: в лексикографическом порядке. После имени кандидата выведите
число набранных им голосов.
Если в каком-либо штате два или более число кандидатов набрали одинаковое
число голосов, то все голоса выборщиков этого штата получает наименьший
в лексикографическом порядке кандидат из числа победителей в этом штате.
Гарантируется, что в каждом штате проголосовал хотя бы один избиратель.
Ввод | Вывод | Комментарии |
---|---|---|
2 |
Bush 25 |
В Florida 2 избирателя голосует за Gore и три избирателяза Bush , поэтому 25 голосов выборщиков от Floria получает Bush . В Pennsylvania побеждает Gore (4 голоса против 1), поэтому Gore получает 23 голоса выборщиков от Pennsylvania . |
3 |
Gore 5 |
В Florida побеждает Gore (5 голосов выборщиков), в Alaska — Bush (2 голоса выборщика). В Pennsylvania два кандидата набрали наибольшее число голосов (по 1), поэтому4 голоса выборщиков от этого штата получает Clinton , т.к. он идет раньше в лексикографическом порядке. |
Решение
input_file = open('input.txt') num_states = int(input_file.readline().strip()) states_electoral = dict() for i in range(num_states): state, electoral = input_file.readline().split() states_electoral[state] = int(electoral) states_res = {state: {} for state in states_electoral} candidate_results = {} for line in input_file: state, candidate = line.split() states_res[state][candidate] = states_res[state].get(candidate, 0) + 1 candidate_results[candidate] = 0 input_file.close() for state in states_res: best = min(states_res[state].items(), key=lambda _: (-_[1], _[0]))[0] candidate_results[best] += states_electoral[state] election_results = sorted(candidate_results.items(), key=lambda _: (-_[1], _[0])) for candidate, result in election_results: print(candidate, result)
23: Родословная: подсчет высоты
В генеалогическом древе у каждого человека, кроме родоначальника, есть ровно один родитель. На рисунке
приведена часть древа рода Романовых, начиная с Петра I Великого.
Каждом элементу дерева сопоставляется целое неотрицательное число, называемое высотой.
У родоначальника высота равна 0, у любого другого элемента высота на 1 больше, чем у его родителя.
Вам дано генеалогическое древо, определите высоту всех его элементов.
Программа получает на вход число элементов в генеалогическом древе (N). Далее
следует (N-1) строка, задающие родителя для каждого элемента древа, кроме родоначальника.
Каждая строка имеет вид имя_потомка имя_родителя
.
Программа должна вывести список всех элементов древа в лексикографическом порядке.
После вывода имени каждого элемента необходимо вывести его высоту.
Эта задача имеет решение сложности (O(n)), но вам достаточно
написать решение сложности (O(n^2)) (не считая сложности обращения
к элементам словаря).
Пример ниже соответствует приведенному древу рода Романовых.
Ввод | Вывод |
---|---|
9 |
Alexander_I 4 |
Решение
input_file = open('input.txt') n = int(input_file.readline().rstrip()) parent_to_child_dict = {} heights = {} all_children = set() all_parents = set() for i in range(n - 1): child, parent = input_file.readline().split() if parent not in parent_to_child_dict: parent_to_child_dict[parent] = [child] heights[parent] = 0 else: parent_to_child_dict[parent].append(child) all_children.add(child) all_parents.add(parent) head = list(all_parents - all_children)[0] def process_subtree(parent_to_child_dict, heights, head, level): heights[head] = level if head in parent_to_child_dict: for child in parent_to_child_dict[head]: process_subtree(parent_to_child_dict, heights, child, level + 1) process_subtree(parent_to_child_dict, heights, head, 0) for name in sorted(heights): print(name, heights[name])
24: Родословная: предки и потомки
Даны два элемента в дереве. Определите, является ли один из них
потомком другого.
Программа получает на вход описание дерева, как в задаче 23.
Далее до конца файла идут строки, содержащие имена двух элементов
дерева. Для каждого такого запроса выведите одно из трех чисел:
1, если первый элемент является предком второго, 2, если второй
является предком первого или 0, если ни один из них не является
предком другого.
Ввод | Вывод |
---|---|
9 |
1 |
Решение
input_file = open('input.txt') num_people = int(input_file.readline().rstrip()) child_to_parent_dict = {} for i in range(num_people - 1): child, parent = input_file.readline().split() child_to_parent_dict[child] = parent def path_to_head(name): global child_to_parent_dict path = {name} if name not in child_to_parent_dict: path while name in child_to_parent_dict: name = child_to_parent_dict[name] path.add(name) return path for line in input_file: name1, name2 = line.split() if name1 in path_to_head(name2): print(1) elif name2 in path_to_head(name1): print(2) else: print(0) input_file.close()
25: Родословная: LCA
В генеалогическом древе определите для двух элементов их наименьшего общего
предка. Наименьшим общим предком элементов A и B является такой элемент C,
что С является предком A, C является предком B, при этом глубина C является наибольшей
из возможных. При этом элемент считается своим собственным предком.
Формат входных данных аналогичен предыдущей задаче. Для каждого запроса выведите
наименьшего общего предка данных элементов.
По-английски такая задача называется lowest common ancestor (LCA).
Ввод | Вывод |
---|---|
9 |
Paul_I |
Решение
input_file = open('input.txt') num_people = int(input_file.readline().rstrip()) child_to_parent_dict = {} for i in range(num_people - 1): child, parent = input_file.readline().split() child_to_parent_dict[child] = parent def path_to_head(name): global child_to_parent_dict path = {name} if name not in child_to_parent_dict: path while name in child_to_parent_dict: name = child_to_parent_dict[name] path.add(name) return path for line in input_file: name1, name2 = line.split() path_from_first_to_head = path_to_head(name1) while name2 not in path_from_first_to_head: name2 = child_to_parent_dict[name2] print(name2) input_file.close()
26: Родословная: Число потомков
Для каждого элемента дерева определите число всех его потомков (не считая его самого).
Формат выходных данных совпадает с задачей 23. Выведите список всех элементов в лексикографическом
порядке, для каждого элемента выводите количество всех его потомков.
Решение должно иметь сложность (O(N)), не считая сложности обращения к элементам словаря
и сортировки результата.
Ввод | Вывод |
---|---|
9 |
Alexander_I 0 |
Решение
input_file = open('input.txt') num_people = int(input_file.readline().rstrip()) child_to_parent_dict = {} number_of_chilren_dict = {} all_children = set() all_parents = set() for i in range(num_people - 1): child, parent = input_file.readline().split() child_to_parent_dict[child] = parent number_of_chilren_dict[parent] = number_of_chilren_dict.get(parent, 0) + 1 all_children.add(child) all_parents.add(parent) input_file.close() head = all_parents - all_children cur_level_of_tree = all_children - all_parents - head num_descendants = {name: 0 for name in cur_level_of_tree} while cur_level_of_tree: next_level_of_tree = set() for name in cur_level_of_tree: parent = child_to_parent_dict[name] num_descendants[parent] = num_descendants.get(parent, 0) + num_descendants[name] + 1 number_of_chilren_dict[parent] -= 1 if number_of_chilren_dict[parent] == 0: next_level_of_tree.add(parent) cur_level_of_tree = next_level_of_tree cur_level_of_tree -= head for name in sorted(num_descendants): print(name, num_descendants[name])
Занятие 10. Множества
Задача «Количество различных чисел»
Условие
Дан список чисел. Определите, сколько в нем встречается различных чисел.
Примечание. Эту задачу на Питоне можно решить в одну строчку.
Во всех задачах считывайте входные данные через input()
и выводите ответ через print()
.
Тесты
Входные данные | Правильный ответ | Что вывела программа | Результат | |
---|---|---|---|---|
1 2 3 2 1 |
3 |
|||
1 2 3 4 5 6 7 8 9 10 |
10 |
|||
1 2 3 4 5 1 2 1 2 7 3 |
6 |
|||
1 1 1 1 1 1 1 1 1 1 1 1 |
1 |
kh_evgenia 0 / 0 / 0 Регистрация: 25.01.2019 Сообщений: 8 |
||||
1 |
||||
Как найти количество различных чисел?30.01.2019, 03:48. Показов 34808. Ответов 5 Метки нет (Все метки)
Добрый день, Есть задача Дан список чисел, который может содержать до 100000 чисел. Вроде все просто:
Но при сдаче пишут, что мой код не достаточно функционален и нельзя использовать FOR, либо DEF(( Подскажите как исправить это чтобы работало?
0 |
z1ne2wo 20 / 15 / 5 Регистрация: 28.08.2018 Сообщений: 18 |
||||
30.01.2019, 04:46 |
2 |
|||
Сообщение было отмечено kh_evgenia как решение Решение
1 |
0 / 0 / 0 Регистрация: 25.01.2019 Сообщений: 8 |
|
30.01.2019, 06:28 [ТС] |
3 |
Спасибо, Буквально только что такое же решение загрузила и оно было принято на 100/100
0 |
0 / 0 / 0 Регистрация: 15.11.2020 Сообщений: 2 |
|
15.11.2020, 15:54 |
4 |
Способ одной строкой: >>> a = {1, 2, 3, 2, 1} Результат: 3
0 |
Am I evil? Yes, I am! 15982 / 8994 / 2604 Регистрация: 21.10.2017 Сообщений: 20,695 |
|
15.11.2020, 15:57 |
5 |
Способ одной строкой: Я вижу две строки
0 |
0 / 0 / 0 Регистрация: 15.11.2020 Сообщений: 2 |
|
15.11.2020, 16:07 |
6 |
А, ну точно, значит “в две”.
0 |
IT_Exp Эксперт 87844 / 49110 / 22898 Регистрация: 17.06.2006 Сообщений: 92,604 |
15.11.2020, 16:07 |
Помогаю со студенческими работами здесь Напишите программу, которая сортирует массив и находит количество различных чисел в нем Как найти количество уникальных чисел? Найти количество чисел в интервале [a, b], и сумму чисел, стоящих на местах, кратных 3 Массив: Найти произведение всех чисел, стоящих на местах, кратных 4, и количество чисел, небольших заданного A. Искать еще темы с ответами Или воспользуйтесь поиском по форуму: 6 |
-
-
Actions
Automate any workflow
-
Packages
Host and manage packages
-
Security
Find and fix vulnerabilities
-
Codespaces
Instant dev environments
-
Copilot
Write better code with AI
-
Code review
Manage code changes
-
Issues
Plan and track work
-
Discussions
Collaborate outside of code
Explore
-
All features
-
Documentation
-
GitHub Skills
-
Blog
-
-
For
-
Enterprise
-
Teams
-
Startups
-
Education
By Solution
-
CI/CD & Automation
-
DevOps
-
DevSecOps
Case Studies
-
Customer Stories
-
Resources
-
-
-
GitHub Sponsors
Fund open source developers
-
The ReadME Project
GitHub community articles
Repositories
-
Topics
-
Trending
-
Collections
-
- Pricing