Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.84/88: Рейтинг темы: голосов - 88, средняя оценка - 4.84
208 / 95 / 15
Регистрация: 27.07.2018
Сообщений: 323

Поиск однофамильцев в списке

12.11.2018, 11:03. Показов 17141. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Начальник кадровой службы хочет узнать, сколько мужчин-однофамильцев работает в организации. У него есть список фамилий, и на основании этого списка нужно вычислить количество фамилий, которые совпадают с другими.

Формат ввода
В первой строке указывается количество мужчин - сотрудников организации (N). Затем идут N строк с фамилиями этих сотрудников в произвольном порядке.

Формат вывода
Количество однофамильцев в организации.
Есть код
Python
1
2
3
4
5
6
7
8
9
10
men_works = set()
men = int(input())
cout = 0
for i in range(men):
    name = input()
    if name in men_works:
        cout += 1
    else:
        men_works.add(name)
print(cout)
По сути всё верно, но как ввести в cout, еще N-ое фамилии, которые были в множестве.
Пример:
Ввод:
6
Иванов
Петров
Сидоров
Петров
Иванов
Петров
Вывод:
5
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.11.2018, 11:03
Ответы с готовыми решениями:

Составить список лиц, не имеющих в списке однофамильцев
1. Сформировать список группы студентов, каждая запись которого имеет следующую структуру: фамилия, имя, отчество, пол. Составить список...

Найти всех однофамильцев в списке участников олимпиады, хранящемся в файле
В файле хранится список участников олимпиады в виде: ФАМИЛИЯ(факультет) (например, ИВАНОВ(ЭОУС), ФАМИЛИЯ - в верхнем регистре). Количество...

Поиск однофамильцев
Не работает код, ругается на строку 20, в чем проблема? using System; using System.Collections.Generic; using System.Linq; using...

7
 Аватар для anapshy
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
12.11.2018, 13:04
Python
1
2
3
4
5
6
7
8
from collections import Counter
line = "Иванов Петров Сидоров Петров Иванов Петров"
counter = Counter(line.split(' ')) # разбить строку по пробелам и посчитать похожие фамилии
result = 0
for last_name in counter:
    result += counter[last_name] if counter[last_name] > 1 else 0
print('counter:', counter)
print('result:', result)
0
 Аватар для Semen-Semenich
5237 / 3481 / 1176
Регистрация: 21.03.2016
Сообщений: 8,310
12.11.2018, 13:13
Лучший ответ Сообщение было отмечено CyberGame как решение

Решение

Цитата Сообщение от CyberGame Посмотреть сообщение
По сути всё верно, но как ввести в cout, еще N-ое фамилии,
по сути даже ответ не верный,вообще то у вас cout это счетчик зачем туда фамилии вводить?
Python
1
2
if name in men_works:
        cout += 1
подразумевает что один у же есть в множестве и вы увеличиваете счетчик на 1 НО изначально счетчик у вас равен 0 и увеличив его на 1 вы получаете 1 хотя считаете уже 2х человек( один в множестве второй получен) и считав третьего и увеличив cout += 1 вы получите результат 2 хотя уже 3 человека однофамильцев. либо получаете все фамилии в список а из списка получаете множество и беря фамилию из множества считаете их количество в списке и если больше 1 то добавляете к общему результату.
Python
1
2
3
4
5
6
7
8
9
10
11
men = int(input())
men_works = [input() for _ in range(men)]
result = 0
for example in set(men_works):
    cout = 0
    for name in men_works:
        if example == name:
            cout += 1
    if cout >1:
        result += cout
print(result)
через словарь если не хотите использовать функцию count()
Python
1
2
3
4
5
6
men = int(input())
men_works = {}
for _ in range(men):
    name = input()
    men_works[name] = men_works.get(name,0)+1
print(sum((i for i in men_works.values() if i >1)))
1
 Аватар для anapshy
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
12.11.2018, 13:13
Python
1
2
3
4
5
6
7
8
9
10
11
line = "Иванов Петров Сидоров Петров Иванов Петров".split()
counter = {}
result = 0
for last_name in line:
    if last_name in counter:
        result += 2 if counter[last_name] is 1 else 1
        counter[last_name] += 1
    else:
        counter[last_name] = 1
print('counter:', counter)
print('result:', result)
0
0 / 0 / 0
Регистрация: 03.01.2019
Сообщений: 30
05.01.2019, 19:53
может объяснить эту строку: print(sum((i for i in men_works.values() if i >1)))
пожалуйста
0
 Аватар для anapshy
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
05.01.2019, 19:55
Алекса07, получить сумму тех значений контейнера men_works, что больше чем 1.
0
0 / 0 / 0
Регистрация: 03.01.2019
Сообщений: 30
05.01.2019, 19:59
можете пожалуйста расписать по строкам?
0
 Аватар для anapshy
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
05.01.2019, 22:44
Алекса07,
Python
1
2
3
container = (i for i in men_wokrs.values() if i > 1)
sum = sum(container)
print(sum)
Добавлено через 1 минуту
Python
1
2
3
4
5
6
#container = (i for i in men_wokrs.values() if i > 1)
container = []
for i in men_works.values():
    if i > 1:
        container.append(i)
print(sum(container))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.01.2019, 22:44
Помогаю со студенческими работами здесь

Поиск однофамильцев
Помогите пожалуйста решить эту задачку... Спасибо... Написать программу-поиск однофамильцев, обучающихся в одном каком-нибудь классе.

Поиск однофамильцев
Задание звучит следующим образом. Создайте базу данных о студентах: фамилия, имя, год рождения. Найдите всех однофамильцев. С БД проблем...

Поиск однофамильцев
Здравствуйте! Обращаюсь к вам за помощью. У меня имеется таблица с Именами и Фамилиями(в одном поле).Мне нужно создать форму,в которую...

Поиск однофамильцев в программе!
Ребята, вот задача: Сводки об ученике состоят из его имени и фамилии и названия класса (году учебы и буквы), в котором он учится. Дан...

Поиск однофамильцев в типизированном файле
Здравствуйте! Не могли бы вы, пожалуйста, проверить, нет ли в моей программе ошибок? Если оные имеются, ничего поправлять не надо, просто...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Функция установки текстового статуса в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru