Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 23.10.2022
Сообщений: 2

Рекурсия: заменить звездочки знаками '+' или '-', так чтобы получившееся арифметическое выражение равнялось 1989

23.10.2022, 22:20. Показов 903. Ответов 2

Студворк — интернет-сервис помощи студентам
задача(рекурсия)
в выражение 12894 * 4193 * 9510 * 8653 * 4381 * 2546 * 1158 * 8645 * 2587 заменить звездочки знаками '+' или '-', так чтобы получившееся арифметическое выражение равнялось 1989
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.10.2022, 22:20
Ответы с готовыми решениями:

Рекурсия: заменить звездочки знаками '+' или '-', так чтобы получившееся арифметическое выражение равнялось 1989
задача(рекурсия) в выражение 12894 * 4193 * 9510 * 8653 * 4381 * 2546 * 1158 * 8645 * 2587 заменить звездочки знаками '+' или '-', так...

проставить знаки так, чтобы полученное арифметическое выражение равнялось заданному m
Задача: между 1 2 3 4 5 6 7 8 9 проставить знаки так, чтобы полученное арифметическое выражение равнялось заданному m. Пример: m=122...

Заменить вопросительные знаки на плюсы или минусы так чтобы выражение стало верным
Проходя мимо барского забора, Антипа увидел выражение вида: ? a1 ? a2 ? ... ? an =  b. Откуда оно там взялось, неизвестно. Наверное,...

2
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18298 / 14222 / 5368
Регистрация: 17.03.2014
Сообщений: 28,900
Записей в блоге: 1
24.10.2022, 12:20
Лучший ответ Сообщение было отмечено Zhur3n как решение

Решение

Zhur3n,
C#
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
static void Main()
{
    numbers = new[] { 12894, 4193, 9510, 8653, 4381, 2546, 1158, 8645, 2587 };
    ops = new char[numbers.Length-1];
    Solve(ops.Length-1);
}
 
static int[] numbers;
static char[] ops;
static char[] OPERATORS = {'+', '-'};
 
static void Solve(int idx)
{
    foreach (var op in OPERATORS)
    {
        ops[idx] = op;
        if (idx > 0)
            Solve(idx-1);
        else
        {
            int result = numbers[0];
            for (int i = 1; i < numbers.Length; i++)
            {
                int operand = numbers[i];
                if (ops[i-1] == '+') result += operand;
                    else result -= operand;
            }
            if (result == 1989)
            {
                Console.Write(numbers[0]);
                for (int i = 1; i < numbers.Length; i++)
                {
                    Console.Write(ops[i-1]);
                    Console.Write(numbers[i]);
                }
                Console.WriteLine();
            }
        }
    }    
}
Результат
Code
1
12894+4193-9510-8653-4381+2546-1158+8645-2587
1
0 / 0 / 0
Регистрация: 23.10.2022
Сообщений: 2
24.10.2022, 20:10  [ТС]
Спасибо, очень сильно выручил)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.10.2022, 20:10
Помогаю со студенческими работами здесь

Сделать так, чтобы 0 равнялось не нулю, а максимальному числу в этом массиве
Здравствуйте, дорогие форумчане. Составил программу: #include &lt;iostream&gt; using std::cout; using std::endl; #include...

Организовать проверку ввода чисел так,чтобы ни одно из них не равнялось 0.
С клавиатуры вводятся три числа.Организовать проверку ввода этих чисел так,чтобы ни одно из них не равнялось 0.(повторять запрос до...

Добавить цифры и знаки арифметических действий так, чтобы получилось правильное арифметическое выражение
Дана конечная последовательность, состоящая из левых и правых скобок различных заданных типов. Как определить, можно ли добавить в нее...

Расставить между цифрами знаки +/- так, чтобы значение полученного выражения равнялось m
Ребят помогите) Дано n (n больше или равно 2) произвольных цифр А1, А2, ... Аn, где Є {1,2,...,9} и произвольное число m.Составить...

Сделать так, чтобы в двух массивах все значения были равными и их скалярное произведение равнялось 4
Как можно сделать так, чтобы в 2-х одномерных массивах все значения были равными и их скалярное произведение равнялось 4 ? Спасибо.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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 и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru