Balanced Lineup POJ-3264

DP分析

  1. 设A[i]是要求区间最值的数列,F[i, j]表示从第i个数起连续2^j个数中的最大值。(DP的状态)
  2. 初状态是F[i,0]=A[i]
  3. 状态转移方程F[i, j]=max(F[i,j-1], F[i + 2^(j-1),j-1])
  1. void RMQ(int num) //预处理->O(nlogn)
  2. {
  3. for(int j = 1; j < 20; ++j) // 这里j的范围根据具体题目数据定义
  4. for(int i = 1; i <= num; ++i) // num为数组内整数的个数
  5. if(i + (1 << j) - 1 <= num)
  6. {
  7. maxsum[i][j] = max(maxsum[i][j - 1], maxsum[i + (1 << (j - 1))][j - 1]);
  8. minsum[i][j] = min(minsum[i][j - 1], minsum[i + (1 << (j - 1))][j - 1]);
  9. }
  10. }

RMQ算法详解

  1. #define _CRT_SECURE_NO_WARNINGS
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<iomanip>
  5. #include<algorithm>
  6. #include<iostream>
  7. #include<string>
  8. #include<cstring>
  9. #include<vector>
  10. #include<stack>
  11. #include<bitset>
  12. #include<cstdlib>
  13. #include<cmath>
  14. #include<set>
  15. #include<list>
  16. #include<deque>
  17. #include<map>
  18. #include<queue>
  19. using namespace std;
  20. typedef long long ll;
  21. int maxnum[50010][20];
  22. int minnum[50010][20];
  23. int main()
  24. {
  25. int num, n, q, i, j, x, y;
  26. while (~scanf("%d%d", &n, &q))
  27. {
  28. for (i = 1; i <= n; i++)
  29. {
  30. scanf("%d", &num);
  31. maxnum[i][0] = minnum[i][0] = num;
  32. }
  33. //DP转态转移,如下
  34. for (j = 1; (1 << j) <= n; j++)
  35. for (i = 1; i + (1 << j) - 1 <= n; i++) // 预处理
  36. {
  37. maxnum[i][j] = max(maxnum[i][j - 1], maxnum[i + (1 << (j - 1))][j - 1]);
  38. minnum[i][j] = min(minnum[i][j - 1], minnum[i + (1 << (j - 1))][j - 1]);
  39. }
  40. while (q--)
  41. {
  42. int ans;
  43. scanf("%d%d", &x, &y);
  44. int z = 0;
  45. while (1 << (z + 1) <= y - x + 1)z++;
  46. ans = max(maxnum[x][z], maxnum[y - (1 << z) + 1][z])//用两个区间中取最大值,两个区间长度相等
  47. - min(minnum[x][z], minnum[y - (1 << z) + 1][z]);
  48. printf("%d\n", ans);
  49. }
  50. }
  51. return 0;
  52. }

RMQPOJ3264的更多相关文章

随机推荐

  1. JQuery : 插件定义

    来源:http://www.cnblogs.com/xcj26/p/3345556.html 一:导言 有些WEB开发者,会引用一个JQuery类库,然后在网页上写一写("#"), ...

  2. make[1]: *** [storage/perfschema/unittest/CMakeFiles/pfs_connect_attr-t.dir/all] 错误 2 解决方法

    make[2]: *** [storage/perfschema/unittest/pfs_connect_attr-t] 错误 1 make[1]: *** [storage/perfschema/ ...

  3. Select逻辑顺序图

    Select逻辑顺序图

  4. 小型互联网公司的IT系统建设思路

    ​​最近一些想创业的一帮兄弟来问我,准备借助互联网的翅膀,做某某事情,并想尽快的做出一个系统平台. 我给的思路,分6个步骤: 需求-> 灵感设计 ->实现 ->迭代改进 ->成 ...

  5. SQL Server In-Memory OLTP Internals for SQL Server 2016

    SQL Server In-Memory OLTP Internals for SQL Server 2016 这份白皮书是在上一份<SQL Server In-Memory OLTP Inte ...

  6. ShiftRows方法简介

    ShiftRows 是HSSFSheet工作薄的方法 ShiftRows(int startRow,int endRow,int n)参数介绍:startRow:开始行endRow:末尾行n:移动n行 ...

  7. 6. 从Encoder-Decoder(Seq2Seq)理解Attention的本质

    1. 语言模型 2. Attention Is All You Need(Transformer)算法原理解析 3. ELMo算法原理解析 4. OpenAI GPT算法原理解析 5. BERT算法原 ...

  8. dma 测试例子

    #include <linux/module.h> #include <linux/slab.h> #include <linux/sched.h> #includ ...

  9. 微信小程序——动态设置swiper的高度

    根据小程序的设定,swiper组件默认高度为150px,无法根据内容来撑高.如果里面的内容固定还好说,直接设置一个高度就可以了.要是里面内容是动态变化的,这个特性使得我们使用这个组件的时候感到诸多不便 ...

  10. mac:Go安装和配置+GoLand安装和使用之完整教程

    前言 作为一个go语言程序员,觉得自己有义务为go新手开一条更简单便捷的上手之路.纵使网上教程很多,但总不尽人意.go的入门门槛还是非常低的,无论是安装还是使用. go安装 go 语言支持以下系统:  ...