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

Задание обрисовать базу друзей

24.08.2022, 00:23. Показов 3181. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание:

1. Создать структуру данных, описывающую закрытую социальную сеть:
1.1 Создать список пользователей с идентификаторами и именами: users
1.2 Создать список кортежей, определяющие дружбу между пользователями: fp
1.3 С помощью цикла создать словарь friendships, где ключ user_id и значение: список друзей
2. Создать функцию, определяющую количество друзей у выбранного пользователя: number_of_friends(user).
3. Создать список из кортежей в формате (Имя пользователя, число друзей)
4. Отсортировать список по полю num_friends в убывающем порядке.

Вот, что у меня получилось.
Во многих местах коряво, безграмотно и некрасиво.

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
66
67
68
69
70
71
72
73
74
75
# 1. Создаём структуру данных, описывающую закрытую социальную сеть:
# -----------------------------------------------------------------------------
 
# 1.1 Создаём список пользователей с идентификаторами и именами: users
 
users = [
{"id": 0, "name": "Алексей"},
{"id": 1, "name" : "Петр"},
{"id": 2, "name": "Александр"},
{"id": 3, "name": "Сергей"},
{"id": 4, "name": "Катя"},
{"id": 5, "name": "Владимир"},
{"id": 6, "name": "Аня"},
{"id": 7, "name" : "Дмитрий"},
{"id": 8, "name": "Ирина"},
{"id": 9, "name": "Дарья"},
{"id": 10, "name": "Женя"}
]
# -----------------------------------------------------------------------------
 
# 1.2 Создаём список кортежей, определяющие дружбу между пользователями: fp
 
fp = [ (0, 1), (0, 2), (1, 2), (1, 3), (3, 4), (4, 10), (4, 5), (5, 6), (5, 8), (5, 7), (6, 8), (7, 8), (8, 9),(10, 6), (10, 2)]
 
# Инициализируем словарь пустым списком для идентификатора каждого пользователя
 
friendships = {user["id"]: [] for user in users}
# -----------------------------------------------------------------------------
 
# 1.3 С помощью цикла создаём словарь friendships, где ключ: user_id 
#     и значение: список друзей
 
for i, j in fp:
    friendships[i].append(j) # Добавить j как друга для i
    friendships[j].append(i) # Добавить i как друга ДЛЯ j
 
print('\n') 
print('словарь friendships - список друзей по значениям id') 
for k,v in friendships.items():
    print(k, '-', v)
# -----------------------------------------------------------------------------    
 
# 2. Создаём функцию, определяющую количество друзей 
#    у выбранного пользователя: number_of_friends(user).
 
def number_of_friends(u):
    return len(friendships[u["id"]])
 
print('\n')
print('количество друзей ')
 
m = 0
for k in users:
    kol = number_of_friends(k)
    print(users[m]['name'],' - ', kol)
    m +=1
# -----------------------------------------------------------------------------
 
# 3. Создаём список из кортежей в формате 
#    Имя пользователя - user["name"], число друзей - number_of_friends(user)
 
num_friends_by_name = [(user["name"], number_of_friends(user)) for user in  users]
 
print('\n')
print('список из кортежей в формате (Имя пользователя, число друзей)')
print(num_friends_by_name)
# -----------------------------------------------------------------------------
 
# 4. Отсортируем список по полю num_friends в убывающем порядке.
 
num_friends_by_name.sort(key = lambda x: x[1], reverse=True)
 
print ('\n')
print ('Сортировка по убыванию ')
num_friends_by_name
Помогите, пожалуйста доработать программу.
( Особенно пункт 2. )
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.08.2022, 00:23
Ответы с готовыми решениями:

Составить Базу Данных “Записная книжка”, в которой представлены адреса и телефоны родственников, друзей и
Составить Базу Данных “Записная книжка”, в которой представлены адреса и телефоны родственников, друзей и знакомых. Напишите приложение...

Как обрисовать рисунок Jpeg в автокаде 2010
Всем доброго времени суток. Имеется генплан поселка в формате Jpeg. Нужно с него начертить генплан в автокаде. Читал про программки...

В два массива введите: имена друзей в текстовом, информацию об их росте в числовой. Далее ПК выводит кто из друзей выше
В два массива введите: имена друзей в текстовом, информацию об их росте в числовой. Далее ПК выводит кто из друзей выше всех

3
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
25.08.2022, 13:21
Цитата Сообщение от Victor_M Посмотреть сообщение
Помогите, пожалуйста доработать программу.
( Особенно пункт 2. )
А что не так?
Цитата Сообщение от Victor_M Посмотреть сообщение
Python
1
2
def number_of_friends(u):
    return len(friendships[u["id"]])
1
740 / 622 / 151
Регистрация: 04.03.2022
Сообщений: 1,272
25.08.2022, 17:09
Я бы написал так вывод во 2 разделе:
Python
1
2
for k in users:
    print(k['name'],' - ', number_of_friends(k))
Ну и в последней строчке print добавить...
1
0 / 0 / 0
Регистрация: 20.08.2022
Сообщений: 9
25.08.2022, 19:21  [ТС]
Спасибо за мнение. Доработаем.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.08.2022, 19:21
Помогаю со студенческими работами здесь

В два массива введите: имена друзей в текстовом, информацию об их росте числовой. Далее ПК выводит кто из друзей выше вс
В два массива введите: имена друзей в текстовом, информацию об их росте числовой. Далее ПК выводит кто из друзей выше всех. У меня есть...

Задание на базу данных
8. Сведения о больных: - фамилия; - возраст; - пол; - номер палаты; - диагноз. Выведите сведения о больных женского пола,...

Имеется задание создать простую базу данных. Создал ERR диаграмму, что с ней не так?
Здравствуйте, Имеется задание: Для задания выше составил ERR диаграмму Преподаватель ругается на то, что БД...

Хочу друзей
Зашла в "личный кабинет", а там пусто:gsorry: ни друзей ничего...хочу друзей

Список друзей
Всем привет ребят. Суть вопроса такова, мне нужно привязать к одной строке, другие.Я создам таблицы, введу данные, но я не знаю как сделать...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru