CSES - UKIEPC 2017 - Results
Submission details
Task:Hiker Safety
Sender:Hannes Ihalainen
Submission time:2017-11-01 12:04:43 +0200
Language:C++
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.06 sdetails
#2ACCEPTED0.07 sdetails
#3ACCEPTED0.05 sdetails
#4ACCEPTED0.04 sdetails
#5ACCEPTED0.04 sdetails
#6ACCEPTED0.04 sdetails
#7ACCEPTED0.05 sdetails
#8ACCEPTED0.04 sdetails
#9ACCEPTED0.03 sdetails
#10ACCEPTED0.08 sdetails
#11ACCEPTED0.09 sdetails
#12ACCEPTED0.03 sdetails
#13ACCEPTED0.04 sdetails
#14ACCEPTED0.04 sdetails
#15ACCEPTED0.14 sdetails
#16ACCEPTED0.04 sdetails
#17ACCEPTED0.04 sdetails

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