Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.70/163: Рейтинг темы: голосов - 163, средняя оценка - 4.70
9 / 9 / 0
Регистрация: 15.08.2017
Сообщений: 10

Задача - Выборы Президента

15.08.2017, 19:33. Показов 32338. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В выборах Президента Российской Федерации побеждает кандидат, набравший свыше половины числа голосов избирателей. Если такого кандидата нет, то во второй тур выборов выходят два кандидата, набравших наибольшее число голосов.

Формат ввода

Каждая строка входного файла содержит имя кандидата, за которого отдал голос один избиратель. Известно, что общее число кандидатов не превосходит 20, но в отличии от предыдущих задач список кандидатов явно не задан. Читайте данные из файла input.txt с указанием кодировки utf8.

Формат вывода

Если есть кандидат, набравший более 50% голосов, программа должна вывести его имя. Если такого кандидата нет, программа должна вывести имя кандидата, занявшего первое место, затем имя кандидата, занявшего второе место. Выводите данные в файл output.txt с указанием кодировки utf8.

Тест 1
Входные данные:
Полуэкт Варфоломеев
Варфоломей Полуэктов
Полуэкт Варфоломеев

Вывод программы:
Полуэкт Варфоломеев


Тест 2
Входные данные:
Полуэкт Варфоломеев
Варфоломей Виссарионов
Виссарион Полуэктов
Варфоломей Виссарионов
Варфоломей Виссарионов
Полуэкт Варфоломеев

Вывод программы:
Варфоломей Виссарионов
Полуэкт Варфоломеев

Совершенно запутался в своем же коде. Прошу прощения. Чувствую сумбурность, но очень поджимают сроки сдачи задач.((
Подскажите как его исправить. Получаю список. но проверка не работает.
Код ниже
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
inFile = open('input.txt', 'r', encoding='utf8')
outFile = open('output.txt', 'w', encoding='utf8')
Votes = 0
Candidates = []
for l in inFile:
__Candidates += l.split('\n')
for string in inFile.readlines():
__Votes += 1
DiffCandidates = dict()
for line in Candidates:
__if line in Candidates:
____DiffCandidates[line] += 1
__else:
____DiffCandidates[line] = 0
 
SortCandidates = sorted(DiffCandidates, key=lambda x: x[0], reverse=True)
print(SortCandidates, file=outFile)
 
inFile.close()
outFile.close()
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.08.2017, 19:33
Ответы с готовыми решениями:

Выборы президента
На выборах президента страны Лимонии побеждает кандидат, набравший более 50% голосов. Если такого кандидата нет, то проводится второй тур,...

Задача Выборы в США
Как известно, в США президент выбирается не прямым голосованием, а путем двухуровневого голосования. Сначала проводятся выборы в каждом...

Задача Выборы в США
Условие Как известно, в США президент выбирается не прямым голосованием, а путем двухуровневого голосования. Сначала проводятся выборы в...

4
224 / 209 / 63
Регистрация: 26.05.2011
Сообщений: 363
16.08.2017, 04:11
Лучший ответ Сообщение было отмечено Muzzy2000 как решение

Решение

Выбирайте
Python
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#---> 1
candidates = {}
voices = 0
 
with open("input.txt", "rt", encoding="utf-8") as f:
    for name in map(str.strip, f):
#         candidates[name] = candidates.setdefault(name, 0) + 1
        candidates[name] = candidates.get(name, 0) + 1
        voices += 1
 
candidates = sorted(candidates.items(), key=lambda x: x[1], reverse=True)
 
with open("output.txt", "wt", encoding="utf-8") as f:
    percent = candidates[0][1] / voices * 100
    if percent > 50:
            print(candidates[0][0], file=f)
            print(candidates[0][0])
    else:
        for name, _ in candidates[:2]:
            print(name, file=f)
            print(name)
 
    
#---> 2
from collections import defaultdict
from operator import itemgetter
 
candidates = defaultdict(int)
voices = 0
 
with open("input.txt", "rt", encoding="utf-8") as f:
    for name in map(str.strip, f):
        candidates[name] += 1
        voices += 1
       
candidates = sorted(candidates.items(), key=itemgetter(1), reverse=True)
 
with open("output.txt", "wt", encoding="utf-8") as f:
    percent = candidates[0][1] / voices * 100
    if percent > 50:
            print(candidates[0][0], file=f)
            print(candidates[0][0])
    else:
        for name, _ in candidates[:2]:
            print(name, file=f)
            print(name)
            
            
#---> 3
from collections import Counter
 
with open("input.txt", "rt", encoding="utf-8") as f:
    candidates = Counter(map(str.strip, f))
    
voices = sum(candidates.values())
 
with open("output.txt", "wt", encoding="utf-8") as f:
    percent = candidates.most_common(1)[0][1] / voices * 100
    if percent > 50:
            print(candidates.most_common(1)[0][0], file=f)
            print(candidates.most_common(1)[0][0])
    else:
        for name, _ in candidates.most_common(2):
            print(name, file=f)
            print(name)
1
9 / 9 / 0
Регистрация: 15.08.2017
Сообщений: 10
16.08.2017, 22:02  [ТС]
pyuser, огромное спасибо. Оказывается все значительно проще было.

Для идущих за мной.
1) Для сдачи роботу оставьте только вывод в файл. Уберите вывод в консоль.

2) Используйте
import io
with io.open("input.txt", "r", encoding="utf-8") as inf:
...
with io.open("output.txt", "w", encoding="utf-8") as out:
...
out.close()
inf.close()

Итоговый код:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import io
 
candidates = {}
voices = 0
 
with io.open("input.txt", "r", encoding="utf-8") as inf:
    for name in map(str.strip, inf):
        candidates[name] = candidates.get(name, 0) + 1
        voices += 1
 
 
candidates = sorted(candidates.items(), key=lambda x: x[1], reverse=True)
 
with io.open("output.txt", "w", encoding="utf-8") as out:
    percent = candidates[0][1] / voices * 100
    if percent > 50:
        print(candidates[0][0], file=out)
    else:
        for name, _ in candidates[:2]:
            print(name, file=out)
out.close()
inf.close()
1
224 / 209 / 63
Регистрация: 26.05.2011
Сообщений: 363
17.08.2017, 06:56
Цитата Сообщение от Muzzy2000 Посмотреть сообщение
out.close() inf.close()
Это лишнее
0
 Аватар для Pavelpds
8 / 8 / 0
Регистрация: 26.01.2019
Сообщений: 35
02.02.2019, 19:55
Еще один вариант решения:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
inFile = open('input.txt', 'r', encoding='utf8')
outFile = open('output.txt', 'w', encoding='utf8')
canString = inFile.readlines()
canList = []
for cand in canString:
    canSp = cand.strip()
    canList.append(canSp)
allVot = len(canList)
canDict = {}
for can in canList:
    canDict[can] = canDict.get(can, 0) + 1
canDict = [(vot, cn) for cn, vot in canDict.items()] #menyaem mestami 
canDict.sort(key=lambda x: x[0], reverse=True)
if canDict[0][0] > (allVot // 2):
    print(canDict[0][1], file=outFile)
else:
    print(canDict[0][1], canDict[1][1], sep="\n", file=outFile)
inFile.close()
outFile.close()
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.02.2019, 19:55
Помогаю со студенческими работами здесь

Задача Выборы на Питоне
На выборах в Государственную думу в избирательные бюллетени внесено N партий. Электронный сканер для считывания информации с бюллетеней...

Задача "Выборы"
Наступил День Мелких Богов, и волшебники должны были избрать себе нового аркканцлера. Ну, не совсем избрать, поскольку волшебники не...

Выборы президента США
Выборы президента США проходят по непрямой схеме. Упрощённо схема выглядит так. Сначала выборы проходят по избирательным округам, на этих...

Выборы президента России 2012 год
как вы думаете (или хотите) кто будет президентом в 12 году я надеюсь на Жириновского, хоть и сомневаюсь что его выберут

Сколькими способами можно выбрать президента общества, вице-президента, ученого секретаря и казначея
Правильно ли решил? Научное общество состоит из 25 человек. Надо выбрать президента общества, вице-президента, ученого секретаря и...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru