Task: | Jakkara |
Sender: | |
Submission time: | 2015-07-19 18:12:23 +0300 |
Language: | C++ |
Status: | READY |
Result: | 100 |
group | verdict | score |
---|---|---|
#1 | ACCEPTED | 21 |
#2 | ACCEPTED | 25 |
#3 | ACCEPTED | 54 |
test | verdict | time | group | |
---|---|---|---|---|
#1 | ACCEPTED | 0.09 s | 1 | details |
#2 | ACCEPTED | 0.08 s | 1 | details |
#3 | ACCEPTED | 0.07 s | 1 | details |
#4 | ACCEPTED | 0.08 s | 1 | details |
#5 | ACCEPTED | 0.09 s | 1 | details |
#6 | ACCEPTED | 0.08 s | 2 | details |
#7 | ACCEPTED | 0.09 s | 2 | details |
#8 | ACCEPTED | 0.08 s | 2 | details |
#9 | ACCEPTED | 0.09 s | 2 | details |
#10 | ACCEPTED | 0.08 s | 2 | details |
#11 | ACCEPTED | 0.07 s | 3 | details |
#12 | ACCEPTED | 0.08 s | 3 | details |
#13 | ACCEPTED | 0.09 s | 3 | details |
#14 | ACCEPTED | 0.08 s | 3 | details |
#15 | ACCEPTED | 0.07 s | 3 | details |
Code
#include <iostream> using namespace std; typedef long long ll; inline ll ABS(ll a) { return a < 0LL ? -a : a; } ll a,b,c,d; ll eval(ll mid) { return ABS(mid-a) + ABS(mid-b) + ABS(mid-c) + ABS(mid-d); } int main() { cin >> a >> b >> c >> d; ll L = 1, R = 100000000000LL; ll best = 999999999999999999LL; while (L <= R) { ll mid = (L+R)/2; ll A = eval(mid-1); ll B = eval(mid); ll C = eval(mid+1); if (B < best) best = B; if (A < B || B < C) { R = mid-1; } else { L = mid+1; } } cout << best << endl; return 0; }
Test details
Test 1
Group: 1
Verdict: ACCEPTED
input |
---|
2 4 2 1 |
correct output |
---|
3 |
user output |
---|
3 |
Test 2
Group: 1
Verdict: ACCEPTED
input |
---|
4 4 5 1 |
correct output |
---|
4 |
user output |
---|
4 |
Test 3
Group: 1
Verdict: ACCEPTED
input |
---|
1 3 3 3 |
correct output |
---|
2 |
user output |
---|
2 |
Test 4
Group: 1
Verdict: ACCEPTED
input |
---|
4 5 2 1 |
correct output |
---|
6 |
user output |
---|
6 |
Test 5
Group: 1
Verdict: ACCEPTED
input |
---|
1 2 3 4 |
correct output |
---|
4 |
user output |
---|
4 |
Test 6
Group: 2
Verdict: ACCEPTED
input |
---|
755 181 899 550 |
correct output |
---|
923 |
user output |
---|
923 |
Test 7
Group: 2
Verdict: ACCEPTED
input |
---|
415 158 928 660 |
correct output |
---|
1015 |
user output |
---|
1015 |
Test 8
Group: 2
Verdict: ACCEPTED
input |
---|
8 786 277 786 |
correct output |
---|
1287 |
user output |
---|
1287 |
Test 9
Group: 2
Verdict: ACCEPTED
input |
---|
740 537 892 1000 |
correct output |
---|
615 |
user output |
---|
615 |
Test 10
Group: 2
Verdict: ACCEPTED
input |
---|
805 794 799 591 |
correct output |
---|
219 |
user output |
---|
219 |
Test 11
Group: 3
Verdict: ACCEPTED
input |
---|
918046201 377309798 763092200 ... |
correct output |
---|
753184325 |
user output |
---|
753184325 |
Test 12
Group: 3
Verdict: ACCEPTED
input |
---|
185264934 19222757 522094385 9... |
correct output |
---|
595938743 |
user output |
---|
595938743 |
Test 13
Group: 3
Verdict: ACCEPTED
input |
---|
727047841 260674959 553589480 ... |
correct output |
---|
678802024 |
user output |
---|
678802024 |
Test 14
Group: 3
Verdict: ACCEPTED
input |
---|
769070856 877861912 488304785 ... |
correct output |
---|
614008750 |
user output |
---|
614008750 |
Test 15
Group: 3
Verdict: ACCEPTED
input |
---|
1 1 1 1000000000 |
correct output |
---|
999999999 |
user output |
---|
999999999 |