nyoj119
来源:互联网 发布:eve捏脸数据男 编辑:程序博客网 时间:2024/06/09 21:06
#include<cstdio> #include<algorithm> #include<cmath> using namespace std; const int N = 100010; int maxsum[N][20], minsum[N][20]; void RMQ(int num) //预处理->O(nlogn) { for(int j = 1; j < 20; ++j) for(int i = 1; i <= num; ++i) if(i + (1 << j) - 1 <= num) { maxsum[i][j] = max(maxsum[i][j - 1], maxsum[i + (1 << (j - 1))][j - 1]); minsum[i][j] = min(minsum[i][j - 1], minsum[i + (1 << (j - 1))][j - 1]); } } int main() { int num, query; int src, des; scanf("%d %d", &num, &query); for(int i = 1; i <= num; ++i) //输入信息处理 { scanf("%d", &maxsum[i][0]); minsum[i][0] = maxsum[i][0]; } RMQ(num); while(query--) //O(1)查询 { scanf("%d %d", &src, &des); int k = (int)(log(des - src + 1.0) / log(2.0)); int maxres = max(maxsum[src][k], maxsum[des - (1 << k) + 1][k]); int minres = min(minsum[src][k], minsum[des - (1 << k) + 1][k]); printf("%d\n", maxres - minres); } return 0; }
0 0
- nyoj119
- nyoj119
- RMQ nyoj119
- nyoj119士兵杀敌(三)
- nyoj119 RMQ问题
- NYOJ119 士兵杀敌(三)
- nyoj119(RMQ算法+线段树)
- nyoj119士兵杀敌(三)
- nyoj119士兵杀敌(三)
- nyoj119 士兵杀敌(三)
- 士兵杀敌(三)||NYOJ119
- NYOJ119 士兵杀敌(三)【线段树】
- NYOJ119 士兵杀敌(三) 线段树
- NYOJ119 士兵杀敌(三)(RMQ算法)
- nyoj119 士兵杀敌(三)RMQ算法
- 【nyoj119】士兵杀敌三(线段树)
- NYOJ119士兵杀敌(三)RMQ问题之ST…
- nyoj119 士兵杀敌(三) (线段树,两个value)
- Python 06:Python控制语句
- 有关墨家的书
- 动态规划(1):基本思路以及步骤
- background-position
- 关于RNN的小结
- nyoj119
- APP界面设计建议
- UVA 11732 "strcmp()" Anyone?
- BestCoder Round #85
- HDU 5755 高斯消元
- 杂记----安全感
- gdb调试core文件2
- LeetCode 122 Best Time to Buy and Sell Stock II
- 把数组拼接成一个字符串 */