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

Андрей добродушный геймер

02.06.2022, 22:59. Показов 2373. Ответов 2

Студворк — интернет-сервис помощи студентам
Андрей очень любит играть в одну никому не известную игру. В процессе игры герой Андрея выполняет задания и получает взамен определенные вещи. Каждая вещь обладает боевым потенциалом (БП), БП - это некоторое целое число X. Если X>0, то вещь нужна для наступления, если X<0, то вещь нужна для обороны, если X=0 то вещь нужна для колдовства.

Боевой потенциал Героя считается как произведение боевых потенциалов всех вещей, которыми он обладает.

Андрей уже долго играет и накопил N вещей. К Андрею обратился его друг Василий с просьбой передать ему какую-нибудь одну вещь для того чтобы спасти героя Василия от гибели. Андрей хочет помочь Василию, однако так же хочет, чтобы его собственный герой обладал максимальным боевым потенциалом после того как отдаст одну из накопленных вещей.

Напишите программу, которая определит какую вещь следует передать Василию.


Формат ввода
На первой строке входных данных находится одно число N - количество предметов, которыми обладает герой Андрея.
На второй строке находится N целых чисел Ai, где Ai - боевой потенциал i-ого предмета.

Ограничения
1 ≤ N ≤ 10^5
-10^9 ≤ Ai ≤ 10^9

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

Пример 1
Ввод:
6
1 2 3 4 5 6
Вывод:
1

Пример 2
Ввод:
6
-1 -2 -3 -4 -5 -6
Вывод:
-6

Пример 3
Ввод:
5
-1 -2 -3 -4 -5
Вывод:
-1

Пример 4
Ввод:
4
0 1 3 4
Вывод:
0

Пример 5
Ввод:
5
0 1 3 4 -5
Вывод:
-5
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.06.2022, 22:59
Ответы с готовыми решениями:

Увы, из меня фиговый геймер...
Из меня последнее время тоже фиговый геймер. Времени хватает только на Heroes of Might and Magic 3 и LineAge2. Беда ещё в том, что в Питере...

Собираю геймер комп примерно до 45 000
Доброе время суток. В компах не очень, скажем так, отстал немного. Собираю комп сыну (1 годик) и себе любимому (45 000 рубликов. Если...

Геймер для написания статей по игровой тематике
Здравствуйте. В начинающий онлайн-журнал требуются авторы, разбирающиеся в современных компьютерных играх. Средний размер...

2
 Аватар для avdivo
303 / 213 / 112
Регистрация: 03.12.2016
Сообщений: 409
03.06.2022, 01:36
Errast,
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 1. если отрицательных элементов нечетное количество - выдаем максисальный отрицательный элемент
# 2. если отрицательных элементов четное количество (в том числе если их нет) - выдать минимальный положительный
# если есть только отрицательные, то минимальный
 
n = int(input('N ')) + 1
a = list(map(int, input().split()))
 
negative = [x for x in a if x < 0]
if len(negative) % 2:
    ret = max(negative)
elif len(negative) == len(a):
    ret = min(a)
else:
    ret = min(set(a) - set(negative))
print(ret)
0
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
03.06.2022, 07:16
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
n   = int( input('n = ') )
lis = list( map( int, input('-> ').split() ) )
has_zero   = False
pos_min    = None
neg_min    = None
neg_max    = None
neg_prod   = 1
if len(lis) == 1:
    print( lis.pop() )
else:
    for e in lis:
        if not e:
            if not has_zero:
                has_zero = True
            else:
                print(0)
                break
        elif e > 0:
            if pos_min == None:
                pos_min = e
            else:
                pos_min = min(e, pos_min)
        else:
            neg_prod *= -1
            if neg_max == None:
                neg_max = e
            else:
                neg_max = max(e, neg_max)
            if neg_min == None:
                neg_min = e
            else:
                neg_min = min(e, neg_min)
    else:
        if has_zero:
            if neg_prod == 1:
                print(0)
            else:
                if pos_min:
                    print(pos_min)
                else:
                    print(neg_max)
        else:
            if neg_prod == 1:
                if pos_min:
                    print(pos_min)
                else:
                    print(neg_min)
            else:
                print(neg_max)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.06.2022, 07:16
Помогаю со студенческими работами здесь

Андрей и акции
Прошу, помогите исправить решение!! Имеется задача: Андрей торгует акциями на бирже. Торги длятся N дней. У Андрея есть информация о...

Граф Андрей
Дан ориентированный невзвешенный граф. Отсортируйте топологически его вершины. Вход. В первой строке содержатся количество вершин n (1...

Андрей и порталы
Андрей вот-вот опоздает на школьный этап ВсОШ. К счастью, недавно в его городе появились порталы. Город, в котором живет Андрей, можно...

Андрей и порталы
Задача 3: Андрей и порталы Андрей вот-вот опоздает на школьный этап ВсОШ. К счастью, недавно в его городе появились порталы. Город,...

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru