0 / 0 / 0
Регистрация: 11.02.2022
Сообщений: 52

Школьные классы и параллели (кортежи)

26.02.2022, 12:49. Показов 7991. Ответов 8

Студворк — интернет-сервис помощи студентам
В школе учится много детей, в каждой параллели могут быть классы с буквами А, Б, В и далее по алфавиту. Определите, в какой параллели среднее количество учеников в классе наименьшее, но не нулевое, а в какой наибольшее.
Формат ввода
Вводится максимальное количество классов в параллели. Затем вводится количество учеников во всех А классах с первого по 11-й, затем в Б и так далее, пока не будут использованы все буквы. Если какой-то буквы в параллели нет, то значение равно 0.
Формат вывода
Вывести параллель с наименьшим средним количеством учеников, затем с наибольшим. Если средние значения одинаковы, то выводить номер наименьший по значению.

Пример
Ввод
2
26
34
22
25
27
18
0
25
16
21
23
27
20
22
26
13
35
0
25
26
0
0

Вывод
5 2
Примечания
В примере ученики распределены по классам параллели так:
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.02.2022, 12:49
Ответы с готовыми решениями:

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

Школьные приколы
Школьные сочинения. Если бы Штирлиц служил больше, чем 17 мгновений весны, он дослужился бы там до Гитлера. Мы с братом взялись...

Школьные программы
Добрый день. Подскажите пжлста, девушка попросила помощи в написании двух легеньких программ, а я в Паскале ... 1. Вывести на экран...

8
290 / 170 / 92
Регистрация: 21.03.2016
Сообщений: 400
26.02.2022, 16:22

Не по теме:

Python
1
2
3
4
5
6
7
8
n = int(input())
students_count_list = [0 for _ in range(11)]
for _ in range(n):
    for i in range(11):
        students_count_list[i] += int(input())
 
print(students_count_list.index(max(students_count_list)) + 1,
      students_count_list.index(min(students_count_list)) + 1)



Неправильно, не сразу понял условие задачи, переделаем.

Добавлено через 3 часа 9 минут
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 average(value):
    count = 0
    for i in value[1]:
        if count == 0:
            count = i
        elif i != 0:
            count = (count + i) / 2
    return count
 
 
def max_min(list_):
    new_list = [i for i in enumerate(zip(*list_), start=1) if average(i) != 0]
    return max(new_list, key=average)[0], min(new_list, key=average)[0]
 
 
def main():
    n = int(input())
    st_list = [[int(input()) for _ in range(11)] for _ in range(n)]
    print(max_min(st_list))
 
 
if __name__ == '__main__':
    assert(max_min([[26, 34, 22, 25, 27, 18, 0, 25, 16, 21, 23],
           [27, 20, 22, 26, 13, 35, 0, 25, 26, 0, 0]]) == (2, 5))
    main()
Попробуй потестируй, вроде так.
1
0 / 0 / 0
Регистрация: 11.02.2022
Сообщений: 52
26.02.2022, 16:56  [ТС]
Нет, ошибка...(

Ввод
2
26
34
22
25
27
18
0
25
16
21
23
27
20
22
26
13
35
0
25
26
0
0
Ожидаемый результат
5 2
Сообщение
Different number of lines: out = 0, corr = 1
0
Вирусоборец
 Аватар для thyrex
14450 / 7489 / 1582
Регистрация: 06.09.2009
Сообщений: 27,133
26.02.2022, 17:38
Лучший ответ Сообщение было отмечено PavelHard как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
n = int(input())
plist = [0 for i in range(11)]
clist = [0 for i in range(11)]
for k in range(n):
    for i in range(11):
        pupils = int(input())
        if pupils != 0:
            plist[i] += pupils
            clist[i] += 1
mii = mai = 0
while clist[mii] == 0:
    mii += 1
    mai += 1
for i in range(mii+1, 11):
    if clist[i] != 0:
        if plist[i]/clist[i]<plist[mii]/clist[mii]:
            mii = i
        if plist[i]/clist[i]>plist[mai]/clist[mai]:
            mai = i
print(mii+1, mai+1)
2
290 / 170 / 92
Регистрация: 21.03.2016
Сообщений: 400
26.02.2022, 18:33
Python
1
2
3
def max_min(list_):
    new_list = [i for i in enumerate(zip(*list_), start=1) if average(i) != 0]
    return min(new_list, key=average)[0], max(new_list, key=average)[0]
Подправил return, теперь сначала минимальное, затем максимальное.

Может тебе строка нужна? тогда так
Python
1
2
3
def max_min(list_):
    new_list = [i for i in enumerate(zip(*list_), start=1) if average(i) != 0]
    return f'{min(new_list, key=average)[0]} {max(new_list, key=average)[0]}'
Добавлено через 50 минут
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
def average(value):
    """Возвращает среднее арифметическое значение не учитывая нулевые"""
    return sum(value[1]) / (len(value[1]) - value[1].count(0))
 
 
def min_max(input_list):
    """Возвращает индекс минимального и максимального среднего числа учащихся в паралели"""
    new_list = (i for i in enumerate(zip(*input_list), start=1) if sum(i[1]) != 0)
    return min(new_list, key=average)[0], max(new_list, key=average)[0]
 
 
def main():
    n = int(input())
    st_list = [[int(input()) for _ in range(11)] for _ in range(n)]
    print(*min_max(st_list))
 
 
if __name__ == '__main__':
    main()
0
0 / 0 / 0
Регистрация: 11.02.2022
Сообщений: 52
26.02.2022, 20:20  [ТС]
Спасибо, всё работает
0
90 / 125 / 28
Регистрация: 17.10.2010
Сообщений: 1,332
27.02.2022, 00:34
Цитата Сообщение от Berbentsev Посмотреть сообщение
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
def average(value):
    """Возвращает среднее арифметическое значение не учитывая нулевые"""
    return sum(value[1]) / (len(value[1]) - value[1].count(0))
def min_max(input_list):
    """Возвращает индекс минимального и максимального среднего числа учащихся в паралели"""
    new_list = (i for i in enumerate(zip(*input_list), start=1) if sum(i[1]) != 0)
    return min(new_list, key=average)[0], max(new_list, key=average)[0]
def main():
    n = int(input())
    st_list = [[int(input()) for _ in range(11)] for _ in range(n)]
    print(*min_max(st_list))
if __name__ == '__main__':
    main()
Не работает.
0
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
27.02.2022, 01:52
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import copy
n = int( input( 'n = ' ) )
lis = [0]*11
for i in range(n):
    for j in range(11):
        val = int( input( '-> ' ) )
        if not val: 
            lis[j] = val
        else:
            lis[j] += val
t = copy.copy(lis)
t.sort()
while True:
    mi = t.pop(0)
    if mi:
        break
print( lis.index(mi) + 1, lis.index( max(lis) ) + 1 )
2
1 / 1 / 0
Регистрация: 17.07.2023
Сообщений: 36
06.06.2024, 12:31
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
n = int(input())
a, b = [], []
for i in range(n):
    for j in range(11):
        b.append(int(input()))
    
    a.append(b)
    b = []
sred = []
for i in range(11):
    k, p = 0, 0
    for j in range(n):
        k += a[j][i]
        if a[j][i] == 0:
            p += 1
    if (n < 3 and p == 0) or (n > 3):
        sred.append(k / n)
print(sred.index(min(sred)) + 1, sred.index(max(sred)) + 1)
у меня только первый тест проходит, а на втором ошибку выдает неправильный ответ. Нужно 9 8, а у меня 1 8. Вывожу результаты вычислений вроде все четко находит. что может быть не так?

Добавлено через 32 минуты
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
n = int(input())
a, b = [], []
for i in range(n):
    for j in range(11):
        b.append(int(input()))
    
    a.append(b)
    b = []
sred = []
for i in range(11):
    k, p = 0, 0
    for j in range(n):
        k += a[j][i]
        if a[j][i] == 0:
            p += 1
    if p == 0:
        sred.append(k / n)
    elif p > 0 and n != p:
        sred.append(k / (n - p))
print(sred.index(min(sred)) + 1, sred.index(max(sred)) + 1)
нашел косяк, вот так все тесты проходит))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.06.2024, 12:31
Помогаю со студенческими работами здесь

Школьные 3 задания
Не могу понять 3 задания. кому не сложно могли бы помочь пожалуйста)

Школьные знакомства
В олимпиаде участвуют 100 школьников. Известно, что для любой группы из 99 школьников найдётся ученик, знакомый с остальными членами...

Школьные шутки
Здесь я хочу поместить тот юмор, который услышал от своих одноклассников, учителей, а заодно – и свой. Шутки от одноклассников (в...

Школьные задачи
1. Как создать конструкцию типа &lt;ключ, массив&gt;, сначала засунуть туда ключи, потом в цикле сравниватьимеющееся значение с ключом и если оно...

Школьные учебники 7-11
Привет всем, срочно разыскиваю учебники по физике в электронном формате, проблема в том, что нужны учебники по которым занимались лет 10-15...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru