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

Между числами нужно расставить знаки + и × так, чтобы в результате получить нечетное число

09.03.2023, 08:56. Показов 8543. Ответов 33

Студворк — интернет-сервис помощи студентам
Сдать решение задачи B-Задача 2
Ограничение времени: 1 с
Ограничение реального времени: 5 с
Ограничение памяти: 64M
Знаки
Сидя на занятиях математики Азамат придумал себе следующую задачу дано число n и последовательность ai из n целых чисел, между числами нужно расставить знаки + и × так, чтобы в результате получить нечетное число. Например между числами 3, 5, 4 можно расставить знаки следующим образом: 3 × 5 + 4 = 19. Помогите Азамату написать программу для решения данной задачи.

Формат входных данных
В первой строке содержится единственное число n (2 ≤ n ≤ 10^5 ).

Во второй строке содержится n целых чисел ai, разделённых пробелами (−10^9 ≤ ai ≤ 10^9 ).

Гарантируется, что решение существует.

Формат результата
В одной строке выведите n − 1 символ + или ×, в результате применения которых получается нечётный результат. (Для вывода используйте соответственно знаки «+» (ASCII код—43) и «x» (ASCII код—120), без кавычек).


Примеры
Входные данные
3
5 7 2
Результат работы
x+
Входные данные
2
4 -5
Результат работы
+

Добавлено через 1 минуту
вот решение мое, оно было не принято
Python
1
2
3
4
5
6
7
8
9
10
n = int(input())
a = list(map(int, input().split()))
 
if 0 in a:
    print("x" * (n-1))
else:
    if any(num % 2 != 0 for num in a):
        print("x" * (n-2) + "+")
    else:
        print("x" * (n-1))
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.03.2023, 08:56
Ответы с готовыми решениями:

Расставить знаки между числами от 1 до 9, чтобы получить заданное число
Доброе время суток. Помогите разобраться с задачей, пожалуйста. Нужно расставить знаки "+", "-" между числами от 1...

Между заданными числами расставить знаки сложения и вычитания так, чтобы в итоге получилось указанное число
Простая задачка из школьной олимпиады (задача на асмп №366). У меня превышает лимит времени. Если есть другие пути поделитесь пж ...

Расставить знаки операций между тремя числами так, чтобы результат вычисления выражения был минимальным
Вы наверняка уже знаете, что Алексей — серьёзный математик, и он любит решать серьёзные задачи. Вот ещё одна из этих задач. Даны три...

33
0 / 0 / 0
Регистрация: 09.03.2023
Сообщений: 15
09.03.2023, 12:27  [ТС]
Студворк — интернет-сервис помощи студентам
Red white socks, 165 номер решения

Добавлено через 40 секунд
Red white socks, номер решения 165

Добавлено через 10 минут
я тут попробовал одно решение
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
n = int(input())
a = list(map(int, input().split()))
 
result = a[0]  # начальное значение результата
 
for i in range(1, n):
    # генерируем все возможные комбинации знаков + и × между предыдущим результатом и текущим числом
    for op in ['+', '*']:
        # вычисляем результат текущей комбинации
        if op == '+':
            new_result = result + a[i]
        else:
            new_result = result * a[i]
        # если результат нечетный, то мы нашли нужную комбинацию знаков и можем завершить циклы
        if new_result % 2 == 1:
            print(op, end='')
            result = new_result
            break
    else:
        # если цикл for не был прерван с помощью break, значит все комбинации дали четный результат
        # в этом случае мы можем выбрать любую комбинацию знаков, например, только +
        print('+', end='')
        result += a[i]
 
print()
вывело что я не прошел тест 6
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,318
09.03.2023, 12:36
Единственно, что может быть «не так» - операции выполняются не по правилам математики, а последовательно:
Python
1
2
3
4
5
6
7
8
9
n = int(input())
a =  list(map(int, input().split()))
res = chr(43) * (n - 1)
if not sum(a)%2:
    for i, v in enumerate(a[::-1]):
        if v % 2 == 1:
            break
    res = res[:n-i-2] + chr(120) + res[n-i-1:]
print(res)
0
0 / 0 / 0
Регистрация: 09.03.2023
Сообщений: 15
09.03.2023, 12:37  [ТС]
Gdez, он выдал ошибку на тесте 4. Возможно есть еще какие либо условия, которые должны проверять код
0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
09.03.2023, 12:39
BeastBoy2209, в коде Gdez поставьте chr(42) вместо chr(120)
0
0 / 0 / 0
Регистрация: 09.03.2023
Сообщений: 15
09.03.2023, 12:43  [ТС]
Red white socks, ошибка в тесте 1
0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
09.03.2023, 12:58
Цитата Сообщение от Gdez Посмотреть сообщение
Единственно, что может быть «не так» - операции выполняются не по правилам математики, а последовательно:
Судя по решению с непрошедшим 6 тестом - так и есть. Умножение нужно поставить перед нечетным числом

Добавлено через 5 минут
Вот это попробуйте
Python
1
2
3
4
5
6
7
8
9
10
n = int(input())
a =  list(map(int, input().split()))
res = chr(43) * (n - 1)
if not sum(a)%2:
    for i, v in enumerate(a):
        if v % 2 == 1:
            break
    i = max(0, i-1)
    res = res[:i] + chr(120) + res[i+1:]
print(res)
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,318
09.03.2023, 12:58
Red white socks, в крайнем коде вроде так и есть.
P.s. ТС лукавит по поводу пройденных пяти тестов - у него в коде знак ‘*’ -> chr(42)
1
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
09.03.2023, 13:05
Цитата Сообщение от Gdez Посмотреть сообщение
P.s. ТС лукавит по поводу пройденных пяти тестов - у него в коде знак ‘*’ -> chr(42)
Именно поэтому я и попросил поставить звездочку в ваш код)) Тут загадок как в докторе Хаусе - верить нельзя никому)
1
Любознательный
 Аватар для YuS_2
7406 / 2260 / 360
Регистрация: 10.03.2016
Сообщений: 5,216
09.03.2023, 14:19
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
while 1:
    n = input("Введите единственное число элементов 2≤n≤10^5 или 'q' для выхода : ")
    if n=='q':
        break
    
    n = int(n)
    if not 2<=n<=10**5:
        # Не выполнено условие 2≤n≤10^5
        print('Условие не выполнено')
        continue
    
    a = list(map(int, input('Введите n целых чисел −10^9≤num≤10^9, через пробел: ').split()))
    if len(a)!=n:
        # Не совпадает количество введенных чисел с указателем числа элементов n
        print('Условие не выполнено')
        break
    q,o = False,True
    for num in a:
        if not (-10**9)<=num<=10**9:
            # Не выполнено условие −10^9≤num≤10^9
            q = True
            break
        elif num%2!=0:
            # Наличие гарантированности результата (одно или больше нечетное число в списке)
            o = False
    
    if q or o:
        print('Условия не выполнены')
        continue
 
    eo,res = 0,''
    for i,item in enumerate(a):
        if eo==0 and i==0:
            eo += item
        elif item%2!=0 and eo%2!=0:
            eo *= item
            res += chr(120)
        else:
            eo += item
            res += chr(43)
 
    print(res)
0
740 / 622 / 151
Регистрация: 04.03.2022
Сообщений: 1,272
09.03.2023, 14:22
Red white socks, а если надо (как в задании сказано) ставить именно 'х', то это 'х' или 'x'? Русский или английский язык? Вот тоже вопрос!
0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
09.03.2023, 14:29
Parramon, там вроде как сказали, что икс должен латинским быть - ASCII 120
0
Любознательный
 Аватар для YuS_2
7406 / 2260 / 360
Регистрация: 10.03.2016
Сообщений: 5,216
09.03.2023, 14:32
Цитата Сообщение от Parramon Посмотреть сообщение
Русский или английский язык? Вот тоже вопрос!
Так ведь:
Цитата Сообщение от BeastBoy2209 Посмотреть сообщение
«+» (ASCII код—43) и «x» (ASCII код—120), без кавычек)
0
0 / 0 / 0
Регистрация: 10.03.2023
Сообщений: 1
10.03.2023, 14:05
Я решил но у меня ошибки в тесте 6 показывает. Почти решил очень близко.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
n = int(input())
a = list(map(int, input().split()))
cnt=0
for i in range(n):
    if a[i]%2:
        cnt+=1
if cnt ==0:
    print(1)
else:
    k = a[0]
    for i in range(1,n):
        if (abs(a[i])*abs(k))%2:
            k*=a[i]
            print("x",end="")
        else:
            if (abs(a[i])+abs(k))%2:
                print("+",end="")
                k+=a[i]
            else:
                print("x",end="")
                k*=a[i]
0
0 / 0 / 0
Регистрация: 10.03.2023
Сообщений: 1
10.03.2023, 14:54
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
n=int(input())
l=input().split()
su=0
um=1
for i in l:
    su+=int(i)
    um*=int(i)
if su%2!=0:
    print('+')
elif um%2!=0:
    print('x')
else:
    print('x+')
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.03.2023, 14:54
Помогаю со студенческими работами здесь

Расставить между числами знаки + и * так, чтобы значение получившегося выражения было равно заданному целому S
Даны N целых чисел X1, X2,...,Xn. Расставить между ними + и * так ,чтобы значение получившегося выражения было равно заданному целому S. ...

Расставить между числами знаки + и - так, чтобы значение получившегося выражения было равно заданному целому S
Даны N целых чисел X1, X2, …, XN. Требуется расставить между ними знаки + и - так, чтобы значение получившегося выражения было равно...

Расставить знаки между цифрами так, чтобы получилось заданное число
Помогите разобраться с алгоритмом. Вот задача: Имеются цифры 1, 2, 3, 4, 5, 6, 7, 8, 9. Необходимо расставить между ними любое...

Расставить между членами последовательности знаки +, -, *, /, так, чтобы получилось заданное число
Помогите решить задачу. Не понимаю как её решить. Дана последовательность из N цифр. Необходимо расставить между ними знаки +, -, *, /,...

Расставить знаки арифметических операций между цифрами числа A, чтобы получить число B
Заданы два целых положительных числа A и B. Расставьте знаки арифметических операций (+, -, *, /) между цифрами числа A, чтобы получить...


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

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

Новые блоги и статьи
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru