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

Расставить арифметические знаки между элементами последовательности и вычислить выражение

24.01.2013, 18:20. Показов 8141. Ответов 26
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день,любимые-уважаемые!
есть очень интересное задание,не знаю,встречался ли кто с таким.
у нас есть 10 чисел в таком порядке:0 1 2 3 4 5 6 7 8 9.Между числами можно ПРОИЗВОЛЬНО вставлять знаки + или -,таким образом мы получим какое-то выражение с результатом.например:
0 + 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8 + 9 = 45
0 - 12 - 3 + 4 + 56789 = 56778
0 - 1 + 234 - 56 - 7 - 89 = 81

Задание:написать программу,которая на входе получит целое число и выпишет все существующие выражения,которые дают результатом это число.То есть,к примеру,если программа получит на входе 45,то как результат выпишет 0+ 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8 + 9 и все остальные выражения,с помощью которых можно получить 45(естественно,выражения,сложенные из цифр 0 1 2 3 4 5 6 7 8 9,идущих по порядку.)
Кто-нибудь о таком слышал?

СРАЗУ ОГОВОРЮСЬ,НУЖНО ВЫПОЛНИТЬ В СИ,в этом заключается основная проблема.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.01.2013, 18:20
Ответы с готовыми решениями:

Правильно расставить арифметические знаки между элементами массива
Добрый день.Помогите,пожалуйста,с решением такой вот задачки : Есть массив цифр - А и есть какое-то целое чило - S. Так вот,нужно...

Расставить арифметические знаки между цифрами, чтобы выполнялось равенство
Если у нас есть пример, в котором не выполняется равенство, допустим: 1 + 2 + 3 + 4 + 5 + 6 = 0 И пользователь должен изменить знаки...

Расставить между парами соседних цифр числа А арифметические знаки, чтобы результат выражения стал равен N
Доброго времени суток. Дали решить вот такую задачку: Даны шестизначное неотрицательное число и целое неотрицательное число N....

26
0 / 0 / 0
Регистрация: 24.01.2013
Сообщений: 49
27.01.2013, 11:54  [ТС]
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от lemegeton Посмотреть сообщение
Мой заработок является коммерческой тайной(sic!) и это не шутка. Ну, на бутерброд с колбасой хватает. Изредка и с красной икрой.
это хорошо))

а вот насчет института Вы учли все.кроме страны...=)поверьте,такое бывает.расписание свое могу выложить,только надо ли это.
и спасибо огромное за код.я Вас так и не поблагодарил.
0
0 / 0 / 0
Регистрация: 24.01.2013
Сообщений: 49
28.01.2013, 20:22  [ТС]
lemegeton, а можно немного пояснить,как именно вы сделали задачу?какой алгоритм или функции использовались..чтоб я это понимал.
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
29.01.2013, 10:04
Лучший ответ Сообщение было отмечено как решение

Решение

Цитата Сообщение от небритый еж Посмотреть сообщение
lemegeton, а можно немного пояснить,как именно вы сделали задачу?какой алгоритм или функции использовались..чтоб я это понимал.
Немного? Ну немного можно.
Для девяти знаков по три варианта ("" aka нет знака, "+" и "-") Существует всего 3 ^ 9 = 19683 варианта. Если рассматривать числа с 0 по 19682 включительно как числа в троичной системе, а каждому значению цифры троичного числа поставить в соответствие один из трех вышеперечисленных знаков, получим все возможные варианты. Цифры троичного числа я выбрал как означающие 0 - нет знака, 1 - "+", 2 - "-".

0 - 000000000 - "0123456789"
1 - 000000001 - "012345678+9"
2 - 000000002 - "012345678-9"
3 - 000000010 - "01234567+89"
4 - 000000011 - "01234567+8+9"
5 - 000000012 - "01234567+8-9"
6 - 000000020 - "01234567-89"
7 - 000000021 - "01234567-8+9"
8 - 000000022 - "01234567-8-9"
9 - 000000100 - "0123456+789"
... и так далее ...
19680 - 222222220 - "0-1-2-3-4-5-6-7-89".
19681 - 222222221 - "0-1-2-3-4-5-6-7-8+9".
19682 - 222222222 - "0-1-2-3-4-5-6-7-8-9".

Таким образом, представляя числа от 0 до 19682 перебираются все возможные варианты перестановок трех знаков.

В коде есть две функции, одна считает значение заданной комбинации, вторая выводит комбинацию на экран.

Добавлено через 1 минуту
Цитата Сообщение от небритый еж Посмотреть сообщение
чтоб я это понимал.
Понимание зависит от вас.
4
0 / 0 / 0
Регистрация: 24.01.2013
Сообщений: 49
29.01.2013, 12:21  [ТС]
lemegeton, Благодарствую,о всемогущий!Всего вам самого презамечательного =)я даже понял.даже почти всё =)
0
0 / 0 / 0
Регистрация: 24.01.2013
Сообщений: 49
07.02.2013, 15:02  [ТС]
lemegeton, подскажите пожалуйста,что означает переменная "int id"?за что она отвечает?
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
07.02.2013, 15:18
В любом месте кода id является порядковым номером комбинации знаков.
В троичном представлении id дает как раз последовательность знаков между цифрами. 0 -- отсутствие знака, 1 -- "+", 2 -- "-".
0
0 / 0 / 0
Регистрация: 24.01.2013
Сообщений: 49
07.02.2013, 15:21  [ТС]
lemegeton, спасибо.разобрался.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.02.2013, 15:21
Помогаю со студенческими работами здесь

Расставить арифметические знаки в выражении
Здравствуйте, хочу представить вашему внимаю одну задачу из олимпиадной работы. У меня самого котелок еще не доварил как её решить, поэтому...

Нужно расставить между числами знаки + или - таким образом, чтобы получилось выражение, значение которого равно s и вывести его на экран
Доброго времени суток Задание: дано n чисел и число s. Нужно расставить между числами знаки + или - таким образом, чтобы получилось...

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

Правильно расставить арифметические знаки в выражении
Задача: Случайным образом создается последовательность натуральных чисел путем их некоторой перестановки. Найти все способы расстановки...

Правильно расставить арифметические знаки в выражении
Дана конечная последовательность, состоящая из левых и правых скобок pазличных заданных типов( «(» «{» «»). Определить, можно ли добавить в...


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

Или воспользуйтесь поиском по форуму:
27
Ответ Создать тему
Новые блоги и статьи
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на 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. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru