Submission #569636

#TimeUsernameProblemLanguageResultExecution timeMemory
569636Minindu2006Rainforest Jumps (APIO21_jumps)C++14
12 / 100
4066 ms34756 KiB
#include "jumps.h" #include <bits/stdc++.h> using namespace std; int adj[2001][2001]; int inf = INT_MAX; int sb1 = 1; void init(int n, vector<int> H) { for(int i=0;i<n-1;i++) if(H[i + 1] != H[i] + 1) { sb1 = 0; break; } if(sb1) return; for(int i=0;i<n;i++) for(int j=0;j<n;j++) adj[i][j] = inf; for(int i=0;i<n;i++) adj[i][i] = 0; for(int i=0;i<n;i++) for(int j=i+1;j<n;j++) if(H[i] < H[j]) { adj[i][j] = 1; break; } for(int i=0;i<n;i++) for(int j=i-1;j>=0;j--) if(H[i] < H[j]) { adj[i][j] = 1; break; } int i, j, k; for(k=0;k<n;k++) { for(i=0;i<n;i++) { for(j=0;j<n;j++) { if (adj[i][j] > (adj[i][k] + adj[k][j]) && (adj[k][j] != inf && adj[i][k] != inf)) adj[i][j] = adj[i][k] + adj[k][j]; } } } } int minimum_jumps(int A, int B, int C, int D) { if(sb1) return C - B; int ans = inf; for(int i=A;i<=B;i++) { for(int j=C;j<=D;j++) ans = min(adj[i][j], ans); } if(ans == inf) return -1; else return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...