| 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 |
