Pagini recente » Cod sursa (job #2964779) | Cod sursa (job #1190464) | Cod sursa (job #167973) | Cod sursa (job #1263312) | Cod sursa (job #2458644)
#include <bits/stdc++.h>
using namespace std;
const int SIZE = (1 << 17);
int pointer = SIZE;
char buffer[SIZE];
char Advance()
{
if(pointer == SIZE)
{
fread(buffer, 1, SIZE, stdin);
pointer = 0;
}
return buffer[pointer++];
}
int Read()
{
int Ans = 0;
char ch = Advance();
while(!isdigit(ch))
ch = Advance();
while(isdigit(ch))
{
Ans = 10 * Ans + (ch - '0');
ch = Advance();
}
return Ans;
}
const int N = 100000 + 3;
const int LG = 17;
int Rmq[N][LG];
int Log[N];
int main()
{
freopen("rmq.in", "r", stdin);
freopen("rmq.out", "w", stdout);
int n = Read(), Q = Read();
for(int i = 1; i <= n; i++)
Rmq[i][0] = Read();
for(int i = 2; i <= n; i++)
Log[i] = 1 + Log[i / 2];
for(int k = 1; (1 << k) <= n; k++)
for(int i = 1; i + (1 << k) - 1 <= n; i++)
Rmq[i][k] = min(Rmq[i][k - 1], Rmq[i + (1 << (k - 1))][k - 1]);
for(int i = 1; i <= Q; i++)
{
int tl = Read(), tr = Read();
int k = Log[tr - tl + 1];
int __min = min(Rmq[tl][k], Rmq[tr - (1 << k) + 1][k]);
printf("%d\n", __min);
}
}
/*const int N = 100000+7;
const int LG = 17;
int RMQ[N][LG];
int Log[N];
int main()
{
freopen("rmq.in", "r", stdin);
freopen("rmq.out", "w", stdout);
int n, q;
n = Read();
q = Read();
for(int i = i; i <= n; i++) {
RMQ[i][0] = Read();
}
for(int i = 2; i <= n; i++) {
Log[i] = 1 + Log[(i>>1)];
}
for(int k = 1; (1 << k) <= n; k++) {
for(int i = 1; i + (1 << k) <= n; i++) {
RMQ[i][k] = min(RMQ[i][k-1], RMQ[i+(1 << (k-1))][k-1]);
}
}
for(int i = 0; i < q; i++) {
int l = Read(), r = Read();
int k = Log[r-l+1];
int out = min(RMQ[l][k], RMQ[r - (1 << k) + 1][k]);
printf("%d\n", out);
}
}
*/