Task: | Hiker Safety |
Sender: | Hannes Ihalainen |
Submission time: | 2017-11-01 12:04:43 +0200 |
Language: | C++ |
Status: | READY |
Result: | ACCEPTED |
test | verdict | time | |
---|---|---|---|
#1 | ACCEPTED | 0.06 s | details |
#2 | ACCEPTED | 0.07 s | details |
#3 | ACCEPTED | 0.05 s | details |
#4 | ACCEPTED | 0.04 s | details |
#5 | ACCEPTED | 0.04 s | details |
#6 | ACCEPTED | 0.04 s | details |
#7 | ACCEPTED | 0.05 s | details |
#8 | ACCEPTED | 0.04 s | details |
#9 | ACCEPTED | 0.03 s | details |
#10 | ACCEPTED | 0.08 s | details |
#11 | ACCEPTED | 0.09 s | details |
#12 | ACCEPTED | 0.03 s | details |
#13 | ACCEPTED | 0.04 s | details |
#14 | ACCEPTED | 0.04 s | details |
#15 | ACCEPTED | 0.14 s | details |
#16 | ACCEPTED | 0.04 s | details |
#17 | ACCEPTED | 0.04 s | details |
Code
#include <iostream> #include <vector> using namespace std; int B; int P; int K; int d[1010]; int A[1010]; int V[1010]; vector<int> ans; int dp[1010][1010]; bool u[1010][1010]; int f(int a, int b){ if (u[a][b]) return dp[a][b]; u[a][b]=1; dp[a][b]=d[b]-d[a]; if (dp[a][b]>B) dp[a][b]=-1; if (b==P) dp[a][b]=1222333444; if (b==P || a==b) return dp[a][b]; dp[a][b]=min(dp[a][b], max(f(a+1, b), f(a, b+1))); return dp[a][b]; } void move(int a){ V[a]++; ans.push_back(a+1); } void f(int a){ if (a==0){ if (V[a]!=P-1) move(a); return; } while (1){ if (V[a]!=P-1 && f(V[a-1], V[a]+1)>=max(A[a], A[a-1])) { move(a); if (V[a]!=P-1) return; }else if (V[a-1]!=P-1 && (V[a]==P-1 || f(V[a-1]+1, V[a])>=max(A[a], A[a-1]))){ f(a-1); }else if (V[a-1]!=P-1){ cout << "impossible\n"; exit(0); }else{ return; } } } int main(){ cin >> B; cin >> P; for (int i=0; i<P; ++i) cin >> d[i]; d[P]=d[P-1]; cin >> K; for (int i=0; i<K; ++i){ cin >> A[i]; cin >> V[i]; --V[i]; } while (V[0]!=P-1) f(K-1); for (auto a : ans) cout << a << " "; cout << "\n"; }
Test details
Test 1
Verdict: ACCEPTED
input |
---|
15000 1000 0 99 218 221 239 269 684 719 1... |
correct output |
---|
1 1 1 1 1 2 1 1 2 4 5 6 7 8 9 ... |
user output |
---|
19 19 19 18 19 19 19 19 19 18 ... |
Test 2
Verdict: ACCEPTED
input |
---|
15000 1000 0 548 712 779 815 978 1511 199... |
correct output |
---|
1 1 1 1 1 1 1 1 1 1 1 2 3 4 5 ... |
user output |
---|
19 19 19 18 18 18 19 18 18 18 ... |
Test 3
Verdict: ACCEPTED
input |
---|
15000 1000 0 277 451 479 672 1238 1604 19... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 4
Verdict: ACCEPTED
input |
---|
15000 1000 0 232 341 342 510 575 942 1137... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 5
Verdict: ACCEPTED
input |
---|
15000 1000 0 980 1535 1694 2048 2430 3117... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 6
Verdict: ACCEPTED
input |
---|
15000 1000 0 179 318 387 529 633 861 872 ... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 7
Verdict: ACCEPTED
input |
---|
15000 1000 0 170 309 371 844 1656 2162 23... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 8
Verdict: ACCEPTED
input |
---|
15000 1000 0 600 1543 1909 1913 2128 2272... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 9
Verdict: ACCEPTED
input |
---|
15000 1000 0 15 24 215 1035 1056 1064 140... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 10
Verdict: ACCEPTED
input |
---|
15000 1000 0 525 1663 1820 1879 3342 4726... |
correct output |
---|
263 615 615 615 615 615 615 61... |
user output |
---|
615 615 615 615 615 615 614 61... |
Test 11
Verdict: ACCEPTED
input |
---|
15000 1000 0 431 1256 1305 1530 3361 3445... |
correct output |
---|
620 620 619 619 619 619 618 61... |
user output |
---|
620 620 619 619 619 619 618 61... |
Test 12
Verdict: ACCEPTED
input |
---|
15000 1000 0 140 162 888 1550 1746 2010 2... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 13
Verdict: ACCEPTED
input |
---|
15000 1000 0 109 153 562 649 1211 1316 15... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 14
Verdict: ACCEPTED
input |
---|
15000 1000 0 73 75 315 351 976 1015 1389 ... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 15
Verdict: ACCEPTED
input |
---|
2 1000 0 1 2 3 4 5 6 7 8 9 10 11 12 1... |
correct output |
---|
999 998 997 998 996 997 995 99... |
user output |
---|
999 998 997 998 996 997 995 99... |
Test 16
Verdict: ACCEPTED
input |
---|
15000 1000 0 171 195 1219 1417 2558 2771 ... |
correct output |
---|
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ... |
user output |
---|
39 39 39 39 39 39 39 39 39 38 ... |
Test 17
Verdict: ACCEPTED
input |
---|
15000 1000 0 2 233 305 553 556 612 937 15... |
correct output |
---|
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ... |
user output |
---|
39 39 39 38 38 39 39 38 38 38 ... |