题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=119

解题思路:

RMQ算法。

不会的可以去看看我总结的RMQ算法。

http://blog.csdn.net/niushuai666/article/details/6624672

代码如下:

#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;
}

代码优化后:

#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std; const int N = 100010;
int maxsum[20][N], minsum[20][N]; //优化1 void RMQ(int num) //预处理->O(nlogn)
{
for(int i = 1; i != 20; ++i)
for(int j = 1; j <= num; ++j)
if(j + (1 << i) - 1 <= num)
{
maxsum[i][j] = max(maxsum[i - 1][j], maxsum[i - 1][j + (1 << i >> 1)]); //优化2
minsum[i][j] = min(minsum[i - 1][j], minsum[i - 1][j + (1 << i >> 1)]);
}
} int main()
{
int num, query;
int src, des;
scanf("%d %d", &num, &query);
for(int i = 1; i <= num; ++i) //输入信息处理
{
scanf("%d", &maxsum[0][i]);
minsum[0][i] = maxsum[0][i];
}
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[k][src], maxsum[k][des - (1 << k) + 1]);
int minres = min(minsum[k][src], minsum[k][des - (1 << k) + 1]);
printf("%d\n", maxres - minres);
}
return 0;
}

优化1:数组由F[N][20]变为F[20][N];

因为数组的地址为a + i + j,对应上面数组,我们需要先循环N的部分,所以

如果是第一种,我们计算时因为i不断变化,我们就需要计算a + i + j

如果是第二种,我们计算时a + i不变,只需要改变j

优化2:

位运算

转载至:http://blog.csdn.net/niushuai666/article/details/7400587

自己也放心不下ST算法

最新文章

  1. python 线程之 threading(二)
  2. [Fraud] China UnionPay defrauded in Macau money laundering scandal
  3. 《极客学院 --NSAttributedString 使用详解-4-UITextKit 简介》学习笔记(待处理)
  4. 71 Query Rank Min Max Successor of BST
  5. 敏捷开发之道(四)Scrum概述
  6. [Hadoop源码解读](五)MapReduce篇之Writable相关类
  7. 有哪些适合学生参与的 C++,网络编程方面的开源项目?
  8. JavaScript中return的用法详解
  9. abstract关键字 super 关键字 类与继承
  10. Neural Network Programming - Deep Learning with PyTorch - YouTube
  11. linux crontab 命令,最小的执行时间是一分钟,如需要在小于一分钟内重复执行
  12. IDEA的Database管理台如何显示
  13. 列式数据库~clickhouse 场景以及安装
  14. 异步编程之使用yield from
  15. vue生命周期图示中英文版Vue实例生命周期钩子
  16. //生成四位数的验证码---&gt;
  17. SRM482
  18. lstm(一) 演化之路
  19. memcached Java Client
  20. Excel 导入遍历

热门文章

  1. PDO基础
  2. Elasticsearch集群状态查看命令
  3. 1 visual studio code 配置C++开发环境 (windows 开发环境)
  4. java web 在tomcat没有正常输出
  5. NX二次开发-UFUN导入图框UF_PART_import
  6. 如何理解Vue的render函数
  7. Visual Studio Code 的简单试用体验
  8. Hadoop主要生态系统简介
  9. NetBeans简介和简单使用
  10. MySQL数据库中,使用 group by 时,不重复字段如何拼接显示