Codeforces Round #415 (Div. 2)A. Straight «A» (暴力)
2017-05-21 16:50
555 查看
A. Straight «A»
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output
Noora is a student of one famous high school. It's her final year in school — she is going to study in university next year. However, she has to get an «A» graduation certificate in order to apply to a prestigious one.
In school, where Noora is studying, teachers are putting down marks to the online class register, which are integers from
1 to k. The worst mark is
1, the best is k. Mark that is going to the certificate, is calculated as an average of all the marks, rounded to the closest integer. If several answers are possible, rounding up is produced.
For example, 7.3 is rounded to
7, but 7.5 and 7.8784 — to
8.
For instance, if Noora has marks
[8, 9], then the mark to the certificate is 9, because the average is equal to
8.5 and rounded to 9, but if the marks are
[8, 8, 9], Noora will have graduation certificate with
8.
To graduate with «A» certificate, Noora
has to have mark k.
Noora got n marks in register this year. However, she is afraid that her marks are not enough to get final mark
k. Noora decided to ask for help in the internet, where hacker Leha immediately responded to her request. He is ready to hack class register for Noora and to add Noora any number of additional marks from
1 to k. At the same time, Leha want his hack be unseen to everyone, so he decided to add as less as possible additional marks. Please help Leha to calculate the minimal number of marks he
has to add, so that final Noora's mark will become equal to
k.
Input
The first line contains two integers
n and k
(1 ≤ n ≤ 100, 1 ≤ k ≤ 100) denoting the number of marks, received by Noora and the value of highest possible mark.
The second line contains n integers
a1, a2, ..., an
(1 ≤ ai ≤ k) denoting marks received by Noora before Leha's hack.
Output
Print a single integer — minimal number of additional marks, that Leha has to add in order to change Noora's final mark to
k.
Examples
Input
Output
Input
Output
Note
Consider the first example testcase.
Maximal mark is 10, Noora received two marks —
8 and 9, so current final mark is
9. To fix it, Leha can add marks
[10, 10, 10, 10] (4 marks in total) to the registry, achieving Noora having average mark equal to
![](http://codeforces.com/predownloaded/34/c9/34c9319e581c38794756ad696c1131bc38d0abf3.png)
. Consequently, new final mark is
10. Less number of marks won't fix the situation.
In the second example Leha can add
[5, 5, 5] to the registry, so that making average mark equal to
4.5, which is enough to have 5 in the certificate.
题意:其实就是让求需要加上多少个k才能使平均分大于等于 (k-0.5)
分析:直接暴力就可以了
AC代码:
#include<stdio.h>
#include<string.h>
double a[200];
int main()
{
int n;
double aim;
scanf("%d%lf",&n,&aim);
double ave=0;
for(int i=0;i<n;i++)
{
scanf("%lf",&a[i]);
ave+=a[i];
}
int t=0;
double ans=ave/(n*1.0);
while(ans<aim-0.5)
{
t++;
ans=(ave+t*aim)/double(n+t);
}
printf("%d\n",t);
}
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output
Noora is a student of one famous high school. It's her final year in school — she is going to study in university next year. However, she has to get an «A» graduation certificate in order to apply to a prestigious one.
In school, where Noora is studying, teachers are putting down marks to the online class register, which are integers from
1 to k. The worst mark is
1, the best is k. Mark that is going to the certificate, is calculated as an average of all the marks, rounded to the closest integer. If several answers are possible, rounding up is produced.
For example, 7.3 is rounded to
7, but 7.5 and 7.8784 — to
8.
For instance, if Noora has marks
[8, 9], then the mark to the certificate is 9, because the average is equal to
8.5 and rounded to 9, but if the marks are
[8, 8, 9], Noora will have graduation certificate with
8.
To graduate with «A» certificate, Noora
has to have mark k.
Noora got n marks in register this year. However, she is afraid that her marks are not enough to get final mark
k. Noora decided to ask for help in the internet, where hacker Leha immediately responded to her request. He is ready to hack class register for Noora and to add Noora any number of additional marks from
1 to k. At the same time, Leha want his hack be unseen to everyone, so he decided to add as less as possible additional marks. Please help Leha to calculate the minimal number of marks he
has to add, so that final Noora's mark will become equal to
k.
Input
The first line contains two integers
n and k
(1 ≤ n ≤ 100, 1 ≤ k ≤ 100) denoting the number of marks, received by Noora and the value of highest possible mark.
The second line contains n integers
a1, a2, ..., an
(1 ≤ ai ≤ k) denoting marks received by Noora before Leha's hack.
Output
Print a single integer — minimal number of additional marks, that Leha has to add in order to change Noora's final mark to
k.
Examples
Input
2 10 8 9
Output
4
Input
3 5 4 4 4
Output
3
Note
Consider the first example testcase.
Maximal mark is 10, Noora received two marks —
8 and 9, so current final mark is
9. To fix it, Leha can add marks
[10, 10, 10, 10] (4 marks in total) to the registry, achieving Noora having average mark equal to
![](http://codeforces.com/predownloaded/34/c9/34c9319e581c38794756ad696c1131bc38d0abf3.png)
. Consequently, new final mark is
10. Less number of marks won't fix the situation.
In the second example Leha can add
[5, 5, 5] to the registry, so that making average mark equal to
4.5, which is enough to have 5 in the certificate.
题意:其实就是让求需要加上多少个k才能使平均分大于等于 (k-0.5)
分析:直接暴力就可以了
AC代码:
#include<stdio.h>
#include<string.h>
double a[200];
int main()
{
int n;
double aim;
scanf("%d%lf",&n,&aim);
double ave=0;
for(int i=0;i<n;i++)
{
scanf("%lf",&a[i]);
ave+=a[i];
}
int t=0;
double ans=ave/(n*1.0);
while(ans<aim-0.5)
{
t++;
ans=(ave+t*aim)/double(n+t);
}
printf("%d\n",t);
}
相关文章推荐
- Codeforces Round #415 (Div. 2) A. Straight «A»
- Codeforces Round #415 (Div. 2)(A,暴力,B,贪心,排序)
- Codeforces Round #415 (Div. 2) A. Straight «A»
- Codeforces Round #415 (Div. 2) A B C 暴力 sort 规律
- Codeforces Round #415 (Div. 1) A Do you want a date?
- Codeforces Round #415 (Div. 2) B. Summer sell-off
- Codeforces Round #415 (Div. 2) B. Summer sell-off
- Codeforces Round #415 (Div. 2)
- (二分)Codeforces Round #415 (Div. 2) D-Glad to see you!
- Codeforces Round #415 (Div. 2) C. Do you want a date?
- Codeforces Round #415 (Div. 2) C. Do you want a date?
- Codeforces Round #415 (Div. 2)
- Codeforces Round #415 (Div. 2)C
- Codeforces Round #415 (Div. 2)-C. Do you want a date?
- Codeforces Round #415 (Div. 2)B. Summer sell-off (水题)
- Codeforces Round #415 (Div. 2)C. Do you want a date? (数学归纳)
- Codeforces Round #415 (Div. 2) C. Do you want a date? 数学
- Codeforces Round #415 (Div. 1) 题解
- Codeforces Round #415 A Straight <<A>>
- Codeforces Round #415 (Div. 2) C. Do you want a date?