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

Задача на рассадку гостей с условием

07.02.2022, 11:51. Показов 5150. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Помогите с решением такой задачи:

Мы знаем количество гостей, ваша задача рассадить всех за стол.

Однако, некоторые гости дали вам список неприятелей, с которыми они не сядут.

Стулья расставили так, что у стола оказалось два крайних места, у которых только один соседний гость. В остальных случаях соседа два.

Определите, можно ли рассадить гостей так, чтобы все оказались довольны.

Ввод:

invited_list - количество приглашённых гостей, 0<invited_list<10
dislike_list - строчный массив неприятелей, ["1-2,3"] - означает, что гость под номером 1 не сядет с гостями 2 и 3

Вывод:
Boolean - возможно ли рассадить гостей так, чтобы они все были довольны


Пример:

invited_list = 4
dislike_list = ["1-2", "3-4"]
get_result(invited_list, dislike_list) = True // [1, 4, 2, 3]
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.02.2022, 11:51
Ответы с готовыми решениями:

Задача про рассадку студентов
В институте планируется пересдача по языкам программирования. Для пересдачи нужно рассадить слушателей по аудиториям. Каждая аудитория...

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

Задача с делением пирога для N гостей
Условие задачи такое: За столом сидят n гостей (вводится с клавиатуры), перед которыми стоит пирог. Пирог и его части можно делить только...

3
 Аватар для VistaSV30
987 / 331 / 79
Регистрация: 10.04.2012
Сообщений: 1,241
Записей в блоге: 4
07.02.2022, 16:28
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
import numpy as np
a = np.arange(1,11) # гости - список по порядку
 
# несовместимые гости c a
b, c, p = np.arange(1,11), np.arange(1,11), True
 
while p == True:
    np.random.shuffle(b)
    np.random.shuffle(c)
 
    n = 0
    for i in a:
        if (i == b[i-1]) or (i == c[i-1]) or (b[i-1] == c[i-1]): n += 1
    if n == 0: p = False
            
print('Номер гостя и несовместимые с ними (номера под номерои гостя во втрой и третьей строках)')
print('', a,'\n', b,'\n',c)
 
print('Вариант рассадки гостей')
a1 = np.arange(1,11) # гости - список по порядку
np.random.shuffle(a1) # вариант рассадки гостей
print(a1)
print('Проверка совместимости - пока не доделал, немного позже если получится')
n = 0
for i in range(1,9):
    print(a1[i], b[a1[i]-1], c[a1[i]-1])
#     if b[a1[i]-1] == a1[i]:
#         print(b[a1[i]-1], a1[i])
2
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
07.02.2022, 21:29
Лучший ответ Сообщение было отмечено Mike_Vazovski как решение

Решение

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
def guests_seating( n, dis ):
    lis = list( range(1, n + 1) )
    bad_pairs = set()
    for e in dis:
        L, de, R = e.partition('-')
        not_frends = set( int(x) for x in R.split(',') )
        for nf in not_frends:
            bad_pairs.add( frozenset( [int(L), nf] ) )
    res = [ [x] for x in lis ]
    flag = True
    while flag:
        flag = False
        for x in res:
            for y in lis:
                if frozenset([x[-1],y]) not in bad_pairs and y not in x:
                    x.append(y)
                    flag = True
                    if len(x) == n:
                        #return x
                        return True
    return False
#==============================================================================
n = 10
dis = '1-2,4,6,8 3-5,7,9 4-1,2,3 5-2,4 6-3'.split()
print( guests_seating( n, dis ) )
2
0 / 0 / 0
Регистрация: 07.02.2022
Сообщений: 2
08.02.2022, 10:02  [ТС]
Спасибо за помощь!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.02.2022, 10:02
Помогаю со студенческими работами здесь

Нужны тесты для решённой задачи про компактную рассадку
Ребят, накидайте, пожалуйста, тестов для задачи Открытая олимпиада школьников по программированию 2014/15, заочный этап Москва,...

Задача с условием
с клавиатуры вводятся 2 числа a и b. если выражение (a mod 100)+(b div 10) четное, то n:=0, если не четное, то n:=1 Знаю, что задача...

Задача с условием
y= ai+b/i,если i&lt;5 ai^2+b,если 5≤i≤10 i^3,если i&gt;10 a=2, b=-0.5,а i-аргумент функции.

Задача с условием
Помогите пожалуйста сделать программу в maple, не получается что-то. Вы взяли в банке кредит 500 тысяч рублей для покупки квартиры под...

Задача Цикл с условием
Помогите пожалуйста решить задачку. Дано число а (1&lt;a&lt;=1.5). Из чисел 1+1/2, 1+1/3, ... напечатать те, которые меньше а.


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru