Решение задачи №685 «Золотой песок» с ACMP
Условие задачи
Сотрудники завода по производству золотого песка из воздуха решили поправить свое финансовое положение. Они пробрались на склад завода, где хранился золотой песок трех видов. Один килограмм золотого песка первого вида они смогли бы продать за A1 рублей, второго вида – за A2 рублей, а третьего вида – за A3 рублей. Так получилось, что у сотрудников оказалось с собой только три емкости: первая была рассчитана на B1 килограмм груза, вторая на B2 килограмм, а третья на B3 килограмм. Им надо было заполнить полностью все емкости таким образом, чтобы получить как можно больше денег за весь песок. При заполнении емкостей нельзя смешивать песок разных видов, то есть, в одну емкость помещать более одного вида песка, и заполнять емкости песком так, чтобы один вид песка находился более чем в одной емкости.
Требуется написать программу, которая определяет, за какую сумму предприимчивые сотрудники смогут продать весь песок в случае наилучшего для себя заполнения емкостей песком.
Входные данные
В единственной строке входного файла INPUT.TXT записано 6 натуральных чисел A1, A2, A3, B1, B2, B3, записанных в одной строке через пробел. Все числа не превосходят 100.
Выходные данные
В единственную строку выходного файла OUTPUT.TXT нужно вывести единственное целое число – сумму в рублях, которую смогут сотрудники заработать в случае наилучшего для себя заполнения емкостей песком.
Решение на C++
#include <iostream>
using namespace std;
main ()
{
int a1,a2,a3,b1,b2,b3,c;
cin>>a1>>a2>>a3>>b1>>b2>>b3;
if(a1<a2)
{
c=a1;a1=a2;a2=c;
}
if(a2<a3)
{
c=a2;a2=a3;a3=c;
}
if(a1<a2)
{
c=a1;a1=a2;a2=c;
}
if (b1<b2)
{
c=b1;b1=b2;b2=c;
}
if (b2<b3)
{
c=b2;b2=b3;b3=c;
}
if (b1<b2)
{
c=b1;b1=b2;b2=c;
}
cout<<a1*b1+a2*b2+a3*b3;
}
Условия задач взяты с сайта acmp.ru