# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
745150 | jjcoder | Rainforest Jumps (APIO21_jumps) | C++14 | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#include <cstdio>
using namespace std;
#define ll long long int
#define ull unsigned long long int
#define forn(a,b) for(int a=0; a<b; a++)
#define FOR(a,b) for(int a=1; a<=b; a++)
#define getmax(a,b) ((a)>(b)?(a):(b))
#define mp(a,b) make_pair(a,b)
#define vi vector<int>
#define vull vector<unsigned long long int>
#define vll vector<long long int>
#define vp vector<pair<int,int>>
#define vs vector<string>
#define pb push_back
#define s(a) sort(a.begin(),a.end())
#define sr(a) sort(a.rbegin(),a.rend())
int z=1e9+7;
int arr[20001],arr1[200010];
// find the number of digit in an integer : floor(log10(n))+1
/*vector<pair<int,int>>vec;
vec.push_back({2,3});
vec.push_back({3,2});
sort(vec.rbegin(),vec.rend());
cout << vec[0].first<<" "<<vec[0].second <<endl;
cout << vec[1].first<<" "<<vec[1].second <<endl;
*/
/*for (auto it = v.begin(); it != v.end(); ++it) { // for map<ll,vector<ll>>qweqwe
cout << "Key: " << it->first << ", Values: ";
for (auto val : it->second) {
cout << val << " ";
}
cout << endl;
}*/
/*for (auto& iter: s) { // for map<int,int>qweqwe
std::cout << iter.first << ": " << iter.second << std::endl;
}*/
/*int factorial(ull y)
{
if(y<=1)return 1;
else return y*factorial(y-1);
}
void setIO(string n)
{
freopen((n+".in").c_str(),"r",stdin);
freopen((n+".out").c_str(),"w",stdout);
}
*/
void init(int N, vi H)
{
return;
}
int minimum_jumps(int A, int B, int C, int D)
{
vi ans;
for(int l=A; l<=B; l++)
{
for(int x=C; x<=D; x++)
{
vp visited,queue_up;
int n=0,k=H[A];
queue_up.pb(mp(H[A],n));
while(!queue_up.empty())
{
n++;
for(int i=l; i>=0; i--)
{
if(H[i]>H[l])
{
queue_up.insert(queue_up.begin(),mp(H[i],n));
break;
}
}
for(int i=l; i<=H.size(); i++)
{
if(H[i]>H[l])
{
queue_up.insert(queue_up.begin(),mp(H[i],n));
break;
}
}
visited.pb(mp(k,n));
queue_up.pop_back();
k=queue_up[queue_up.size()-1].first;
}
for(int i=0; i<=visited.size(); i++){
if(visited[i].first==x)ans.pb(visited[i].second);
}
}
}
s(ans);
return s[0];//ans
}
int xmain()
{
//setIO("input");
ios::sync_with_stdio(0);
return 0;
}