Предмет: Информатика, автор: amz2012

Василий мечтает о карьере преподавателя информатики, поэтому очень хочет улучшить свою оценку по этому предмету. В школе, в которой учится Вася, на уроках информатики ответы учеников оцениваются целым числом баллов от 2 до 5. В итоге оценка по информатике выставляется как среднее арифметическое оценок на всех уроках, округленное до ближайшего целого числа. Если среднее значение находится ровно посередине между двумя целыми числами, то оценка округляется вверх. Т. е. если например средняя оценка 3.3, то итоговая будет 3, а если 3.5, то итоговая оценка 4. Вася стремится получить итоговую оценку по информатике не ниже 4 баллов. К сожалению, он получил на уроках X двоек, Y троек и Z четверок. Теперь Вася планирует получить несколько пятерок. Причем он хочет, чтобы итоговая оценка была не меньше 4 баллов. Ему надо понять, какое минимальное количество пятерок ему необходимо получить, чтобы добиться своей цели. Помогите Васи написав программу, которая по заданным целым неотрицательные числам a, b и c определяет минимальное количество пятерок, которое необходимо получить Василию, чтобы его итоговая оценка по информатике была не меньше 4 баллов.
Формат ввода
Входные данные содержат три строки. Первая строка содержит целое неотрицательное число X, вторая строка содержит целое неотрицательное число Y, третья строка содержит целое неотрицательное число Z (0 ≤ X, Y, Z ≤ 10**15, X + Y + Z ≥ 1).
Формат вывода
Выходные данные должны содержать одно число: минимальное число пятерок, которое необходимо получить ученику, чтобы итоговая оценка была не меньше 4 баллов.
Пример Ввод 2 0 0 Вывод 2

Ответы

Автор ответа: Sereybrum
1

Ответ:

#include <QCoreApplication>

#include <bits/stdc++.h>

#include <iostream>

#include <stdio.h>

using namespace std;

int main(int argc, char *argv[])

{

   QCoreApplication ap(argc, argv);

   FILE *fp, *fout;

   long long a, b, c, m;

   fp = fopen ("0","r+");

   fscanf (fp, "%lld\n%lld\n%lld", &a, &b, &c);

   fclose(fp);

   long long sum = 2 * a + 3 * b + 4 * c;

   long long cnt = a + b + c;

   long long l = 0, r = cnt + 1;

   // Алгоритм бинарного поиска

   while (l < r)

   {

        m = (l + r) / 2;

       if ((sum + 5.0 * m) / (cnt + m) < 3.5)

           l = m + 1;

       else

           r = m;

   }

   fout = fopen ("0.a","w+");

   fprintf (fout,"%lld",l);

   fclose(fout);

   return

Объяснение:


amz2012: это что за язык
Похожие вопросы
Предмет: История, автор: alika675
Предмет: Математика, автор: Arty1111
Предмет: Математика, автор: МЕ16102005