Акция выходного дня. Необходимо сделать скидку в определенном размере. Скидка является целым числом. Необходимо распределить скидку по товарам таким образом, чтобы и сумма и цена были целыми числами. Количество товара является целым числом и не изменяется. Сумму по позициям можно как уменьшать, так и увеличивать. Необходимо чтобы отклонения цены были как можно ближе к первоначальным ценам.
Файлы
ВНИМАНИЕ:
Файлы из Базы знаний - это исходный код разработки.
Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы.
Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных.
Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.
Наименование
Скачано
Купить файл
По подписке PRO
Как сделать скидку на определенную сумму (целое число), чтобы цена оставалась целым числом?:
Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».
0% комиссии — оплата напрямую исполнителю;
Исполнители любого масштаба — от отдельных специалистов до команд под проект;
Прямой обмен контактами между заказчиком и исполнителем;
Безопасная сделка — при необходимости;
Рейтинги, кейсы и прозрачная система откликов.
Во вложенной обработке рассмотрен пример поиска оптимальных наборов цен и сумм, с минимальным отклонением от первоначальной цены.
Входные данные:
Цена*Количество=Сумма
3*7=21,
5*8=40,
9*2=18
Итог: 79
Скидка: 9
Найденный набор:
2*7=14,
6*8=48,
4*2=8.
Итог: 70
Как это сделано.
Для каждой строки строится таблица значений из сумм и цен. Берется интервал от "Количество" до "Количество+5"*"Цена". Перебираются целые числа из этого интервала. При каждой итерации число интервала делится на "Количество", проверятся, "Цена" целое число или не целое. Если цена целое число, то заносим значение в таблицу значений. Для каждой строки таблицы с товарами получается таблица значений из нескольких строк. Далее перебираются все строки всех таблиц и найденные наборы (где сумма соответствует сумме со скидкой) заносятся в еще одну таблицу значений, в которой ищется наиболее близкий набор (в котором цена меньше всего отклоняется).
В обработке реализованы 2 варианта поиска наборов. Первый вариант реализован при помощи запроса(таблицы значений помещаются в временные таблицы и таблицы связываются между собой), второй вариант при помощи рекурсии.