RMQ
# include <stdio.h>
# include <string.h>
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
# define N 100005
# define L 18
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int n,k;
int a[N<<1], s[N<<1], r[N<<1][L];
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
void init(void)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int i;
// memset(a, 0, sizeof(a));
// memset(s, 0, sizeof(s));
// memset(r, 0, sizeof(r));
scanf("%d%d", &n, &k);
s[0] = 0;
for (i = 1; i <= n; ++i)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
scanf("%d", &a[i]);
s[i] = s[i-1]+a[i];
r[i][0] = i;
}
for (; i <= 2*n; ++i)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
a[i] = a[i-n];
s[i] = s[i-1]+a[i];
r[i][0] = i;
}
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int Max_t(int x, int y)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
return s[x]>=s[y] ? x:y;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
void pre(void)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int i, j, l;
for (j = 1, l = 1; l*2 <= n*2; l*=2, ++j)
for (i = 1; i+l*2 <= 2*n+1; ++i)
r[i][j] = Max_t(r[i][j-1], r[i+l][j-1]);
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int rmq(int s, int t)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int j = 0, l = 1;
while (l*2 <= t-s+1) l*=2, ++j;
return Max_t(r[s][j], r[t-l+1][j]);
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
void solve(void)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int i, ans = -0x7FFFFFFF, tmp, ti, tj;
for (i = 1; i <= n; ++i)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
tmp = rmq(i, i+k-1);
if (s[tmp]-s[i-1] > ans)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
ans = s[tmp]-s[i-1];
ti = i, tj = tmp;
}
}
ti = (ti+n-1)%n+1;
tj = (tj+n-1)%n+1;
if (ti == tj) ans = a[ti], printf("%d %d %d\n", ans, ti, tj);
else printf("%d %d %d\n", ans, ti, tj);
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int main()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int T;
scanf("%d", &T);
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
while (T--)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
init();
pre();
solve();
}
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
return 0;
}
posted on 2012-08-28 08:24
yajunw 阅读(184)
评论(0) 编辑 收藏 引用