Pagini recente » Cod sursa (job #1091605) | Cod sursa (job #2311572) | Cod sursa (job #1309179) | Borderou de evaluare (job #2523786) | Cod sursa (job #1969325)
#include <fstream>
#include <cstring>
#include <vector>
#include <algorithm>
#include <stack>
#include <iomanip>
#include <queue>
using namespace std;
ifstream fin("rmq.in");
ofstream fout("rmq.out");
#define nmax 100010
int doi[20],rmq[nmax][20],n,m,i,j,logb2[nmax],a[nmax];
int main()
{
fin >> n >> m;
doi[0]=1;
for (i=1; i<20; i++)
doi[i]=doi[i-1]*2;
for (i=2; i<=n; i++)
logb2[i]=logb2[i/2]+1;
for (i=1; i<=n; i++)
{
fin >> a[i];
rmq[i][0]=a[i];
}
int k=logb2[n];
for (i=1; i<=k; i++)
{
for (j=1; j<=n-doi[i]+1; j++)
rmq[j][i]=min(rmq[j][i-1],rmq[j+doi[i-1]][i-1]);
}
for (i=1; i<=m; i++)
{
int x,y;
fin >> x >> y;
int d=logb2[y-x+1];
fout << min(rmq[x][d],rmq[min(max(y-doi[d]+1,1),n)][d]) << '\n';
}
// for (i=0; i<=k; i++)
// {
// for (j=1; j<=n; j++)
// fout << rmq[j][i] << ' ';
// fout << '\n';
// }
}