E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
一维RMQ
pku1743 Musical Theme
给出一个关于LCP的定理LCP(SA[i], SA[j]) =
RMQ
(Height[i+1.
·
2015-11-13 03:49
theme
pku2299 Ultra-QuickSort
; 500,000 ,结果不用说肯定是超时的;于是思路转向了O(nlogn)的算法,换言之离不开二分、树型结构等方法 这里用到的是杨挺的PDF《树状数组和线段树》里提到的方法:巧妙地将问题转化成类似求
RMQ
·
2015-11-13 03:36
Quicksort
RMQ
& LCA
RMQ
是给定一列数,动态询问[i,j]区间内的最小(或最大值)。 LCA是给定一棵树,动态询问u和v的最近公共祖先。 解决这两种问题都有个很重要的倍增思想(这个思想
·
2015-11-13 03:30
MQ
poj 3264
RMQ
直接写个
RMQ
就能过。
·
2015-11-13 02:26
poj
[POJ3368 Frequent values]
[题目来源]:Ulm Local 2007 [关键字]:
RMQ
[题目大意]:给定一个非递减的整数序列(n),然后给出m个查询区间,针对每一个查询,输出此区间内重复最多的数字重复的次数。
·
2015-11-13 02:34
value
UVALive 6531 Go up the ultras 单调栈+
RMQ
题目链接:点击打开链接 题意: 给定n座山 以下n个数字表示n座山的高度 若这座山u合法,则要满足: 1、若u的左边存在比u高的山,设v是u左边距离u近期的且严格比u高的山,在[v,u]之间至少有一座山x,使得x和u的高度差>=15000 2、右边也同理。 同一时候满足1、2的情况则算合法。 问: 输出全部合法的山。 思路: 求距离某个点近期的山就是维护一个单调栈
·
2015-11-13 01:15
live
POJ 3264 Balanced Lineup (
RMQ
分析)
id=3264
RMQ
(Range Minimum/Maximum Query)问题是指:对于长度为n的数列A,回答若干询问
RMQ
(A,i,j)(i,j<=n),返回数列A中下标在
·
2015-11-13 01:19
poj
POJ2201+
RMQ
1 /* 2
RMQ
3 */ 4 #include<stdio.h> 5 #include<string.h> 6 #include<stdlib.h
·
2015-11-13 00:48
poj
RMQ
算法
概述
RMQ
(Range Minimum/Maximum Query),即区间最值查询,是指这样一个问题:对于长度为n的数列A,回答若干询问
RMQ
(A,i,j)(i,j<=n),返回数列A中下标在
·
2015-11-13 00:39
算法
HDU 1806
pid=1806 非常玄妙的
rmq
问题,这个st算法有点神 #include <iostream> #include <cmath> using namespace
·
2015-11-13 00:55
HDU
poj3368Frequent values(
RMQ
)
然后想
RMQ
想出来了 算是离散吧 把每个数出现的次数以及开始的位置及结束的位置记录下来 以次数进行
RMQ
再特殊处理下区间端点就OK 了 WA一次 盯了半小时 原来少了个=号 好吧好吧
·
2015-11-13 00:53
value
poj3264Balanced Lineup(
RMQ
)
id=3264
RMQ
讲解 http://dongxicheng.org/structure/lca-
rmq
/ j = log2K dp[i][j] = max(dp[i][j-1]+dp
·
2015-11-13 00:51
poj
[后缀数组小结]
最长公共前缀:LCP(i,j)=lcp(sa[i],sa[j])=height数组中的i+1,j的最小值
RMQ
解决。
·
2015-11-13 00:25
后缀数组
[BZOJ1787 Meet]
===================== [分析]:无论怎么建树,这个集合点一定在这三个点两两的LCA之间,所以就转化成求LCA的问题,但这道题用离线的tarjan算法十分麻烦,所以就用的LCA转
RMQ
·
2015-11-13 00:59
ZOJ
RMQ
算法学习
概述
RMQ
(Range Minimum/Maximum Query),即区间最值查询,是指这样一个问题:对于长度为n的数列A,回答若干询问
RMQ
(A,i,j)(i,j<=n),返回数列A中下标在
·
2015-11-12 23:10
算法
Lca与
Rmq
关于LCA和
RMQ
问题 一、最近公共祖先(Least Common Ancestors) 对于有根树T的两个结点u、v,最近公共祖先LCA(T,u,v)表示一个结点x,满足x是u、v的祖先且x的深度尽可能大
·
2015-11-12 22:02
MQ
RMQ
ST算法(Sparse Table),以求最大值为例,设d[i,j]表示[i,i+2^j-1]这个区间内的最大值,那么在询问到[a,b]区间的最大值时答案就是max(d[a,k], d[b-2^k+1,k]),其中k=[ln(b-a+1)/ln(2)](即2^k<=b-a+1(长度)) d的求法可以用动态规划,d[i,j]=max(d[i,j-1],d[i+2^(j-1),j-1])
·
2015-11-12 22:01
MQ
URAL 1297 Palindrome 最长回文子串
另外一个是
RMQ
的时候,询问rk[i],rk[j]的最长前缀应该是等效于求lcp[rk[i]] lcp[rk[j
·
2015-11-12 22:46
ROM
POJ 3264 Balanced Lineup
RMQ
回顾一下一些基础算法,Sparse Table有种dp的感觉,写起来有点棘手吧,主要是因为下标的问题,贴一记代码,等下写一个非递归的线段树试试。 #pragma warning(disable:4996) #include<iostream> #include<cstring> #include<string> #include<algorit
·
2015-11-12 22:46
poj
RMQ
数组下标0-n-1,询问区间最值 int dp[100005][20]; void makermq(int n, int *a) { for(int i = 0; i < n; i++) dp[i][0] = a[i]; for(int j = 1; (1<<j) <= n; j++) for(int i
·
2015-11-12 21:30
MQ
URAL 1297 后缀数组:求最长回文子串
然后看题解,里面都是用
RMQ
先预处理随意两个后缀的最长公共前缀,由于不太知道这个,所以又看了一下午,嘛嘛…… 然后理解
RMQ
和后缀一起用的时候才发现事实上这里不用
RMQ
也能够,仅仅要特殊处理一下
·
2015-11-12 19:41
后缀数组
lca
pid=2586 无根树转有根树,基于
rmq
算法计算lca,模板题 #include <iostream> #include <cstdio> #include
·
2015-11-12 18:21
ca
hdu 1806 Frequent values
rmq
+游标编码
白书P198#include usingnamespacestd; constintMAXN=100000+5; inta[MAXN],va[MAXN],num[MAXN],L[MAXN],R[MAXN]; intd[MAXN][20]; voidrmq_max(intn) { for(inti=0;i
xinag578
·
2015-11-12 18:00
TOJ 4325
RMQ
with Shifts / 线段树单点更新
RMQ
with Shifts 时间限制(普通/Java):1000MS/3000MS 运行内存限制:65536KByte 描述  
·
2015-11-12 18:08
with
UVA 11235 (游程编码+ST算法)
尽管一眼就能看出来是个
RMQ
。 关键在于如何转化为
RMQ
。 首先对序列进行游程编码,压缩成pos段。 编码的同时用num[i]记录当前点在
·
2015-11-12 17:38
uva
poj 3368 Frequent values
这题可以用
RMQ
来做,比较区间两端的个数和不同于最大重复个数(
RMQ
)。
·
2015-11-12 16:30
value
HDU 3486 Interviewe
题解:二分k,然后求
RMQ
检验。
·
2015-11-12 16:46
interview
C++模板:ST算法
//初始化 void init_
rmq
(int n){ for(int i=0;i<n;i++)d[i][0]=a[i]; for(int j=1;(1<<
·
2015-11-12 16:45
C++
poj3368
RMQ
由于给出的查询次数很多,我就考虑用
RMQ
来解,但是这个不能直接套用模板,因为加入我们对区间[i,j]进行查询,如果从k处分开取两边区间的最大的重复次数是不一定正确的,因为分开的那个地方可能把实际重复次数最多的那个数一分为二
·
2015-11-12 16:09
poj
poj2452 Sticks Problem
RMQ
问题
我看的题目分类说这个题目用
RMQ
,所有就用了
RMQ
实现,由于开始的时候我是枚举的所有的区间,所以肯定超时,后来改为从i找出以i开始的最大区间范围,然后在这个范围内求出最大值的下标j,那么j就是从i开始的所
·
2015-11-12 16:08
poj
poj1330Nearest Common Ancestors LCA问题 dfs+
rmq
题目意思很简单就是求两个节点的LCA,这个问题可以转化为
rmq
问题,求区间的最小值。
·
2015-11-12 16:06
REST
POJ 3264 Balanced Lineup【
RMQ
-ST算法-区间最值】
Description For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line up in the same order. One day Farmer John decides to organize a game of Ultimate Frisbee with
·
2015-11-12 15:07
poj
UESTC 912 树上的距离 --LCA+
RMQ
+树状数组
做法:先把求LCA解决,LCA可以转化为
RMQ
问题,可参见:LCA转
RMQ
·
2015-11-12 14:09
树状数组
给出一个长度为n的数列,请对于每一个数,输出他右边第一个比他大的数。n<=100000.
首先,做一次
RMQ
,求区间最大值。 对于任意一个数s[i],可以用logn的时间求出他右边第一个比他大的数:
RMQ
[i][j] 表示从s[i]开始的2^j个数中的最大值。
·
2015-11-12 14:08
长度
RabbitMQ学习之:(三)第一个
RMQ
的程序 (转贴+我的评论)
RabbitMQ for Windows: Building Your First Application Posted by Derek Greer on March 7, 2012 This is the second installment to the RabbitMQ for Windows series. In our f
·
2015-11-12 14:29
rabbitmq
RabbitMQ学习之:(一)初识、概念及心得
因为网上有一篇很好的
RMQ
的入门帖子http://lostechies.com/derekgreer/tag/rabbitmq/,所以我就不多说了,就说说我目前看了该作者1~5章后,自己的心得。
·
2015-11-12 14:28
rabbitmq
poj3264Balanced Lineup(线段树
RMQ
)
RMQ
(Range Minimum/Maximum Query)问题是指:对于长度为n的数列A,回答若干询问
RMQ
(A,i,j)(i,j<=n),返回数列A中下标在i,j里的最小(大)值,也就是说
·
2015-11-12 14:31
poj
poj 1330 LCA问题 (LCA问题转化为
RMQ
|| tarjan算法)
LCA问题可以与
RMQ
问题互相转化,长郡中学 郭华阳的《
RMQ
&LCA问题》讲的很好。
·
2015-11-12 11:01
tar
rmq
问题--st算法
概述
RMQ
(Range Minimum/Maximum Query),即区间最值查询,是指这样一个问题:对于长度为n的数列A,回答若干询问
RMQ
(A,i,j)(i,j<=n),返回数列A中下标在
·
2015-11-12 11:59
算法
RMQ
总结
范围最小值问题(Range Minimum/Maximum Query,
RMQ
)。
·
2015-11-12 11:15
总结
二模 (13)day1
虽然本题2s的时限
RMQ
+二分应该也不会超时,但是容易写错。而单调栈不仅O(N)的复杂度,写起来也简单。。 2.具体做法是:从左往右边扫一遍,维护一个单调递减
·
2015-11-12 10:26
a
POJ 3368 Frequent values(
RMQ
)
思路 :其实我一开始没觉得用
RMQ
简单,而且我也没想到怎么用
RMQ
。。。。。听会神讲了才会了。
·
2015-11-12 09:39
value
POJ 3264 Balanced Lineup(
RMQ
)
思路 : 刚好符合
RMQ
的那个求区间最大最小值,所以用
RMQ
还是很方便的。就是一个
RMQ
的模板题,基本上书上网上都有。
·
2015-11-12 09:38
poj
后缀数组的构建
后缀数组相对后缀树来说比较容易构建,应用也比较广泛,和lcp,
RMQ
问题联合运用在各种竞赛中叶比较热门,究竟什么是后缀数组,怎么构建和应用,是像我这样的初学者遇到的最大的问题。
·
2015-11-12 09:16
后缀数组
POJ 3368
RMQ
-ST
一直感觉
RMQ
水,没自己写过,今天写了一道题,算是完全独立写的,这感觉好久没有了...
·
2015-11-12 08:11
poj
LCA与
RMQ
一、什么是LCA? LCA:Least Common Ancestors(最近公共祖先),对于一棵有根树T的任意两个节点u,v,求出LCA(T, u, v),即离跟最远的节点x,使得x同时是u和v的祖先。 二、算法分类 求LCA的算法很多,按照是否在线可以分为在线算法和离线算法。 &
·
2015-11-11 19:54
MQ
(DFS/LCA/
RMQ
)
How far away ? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 5492 Accepted Submission(s): 2090 Pr
·
2015-11-11 19:25
HDU
UVa12299 -
RMQ
with Shifts
题目大意 给定一个长度为n的序列A,可以对其进行一下两种操作: 1、query (L, R) 查询区间[L,R]的最小值 2、shift(i1, i2, i3,..., ik)(i1 < i2 < ... < ik, k > 1) 把元素A[i1],A[i2],…,A[ik]循环移动 题解 区间最小值查询+单点修改。。。水题。。。。 代码:
·
2015-11-11 17:17
with
hdu 1754:I Hate It(线段树,入门题,
RMQ
问题)
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 33726 Accepted Submission(s): 13266 Probl
·
2015-11-11 17:42
HDU
POJ 3264 Balanced Lineup --
RMQ
或线段树
一段区间的最值问题,用线段树或
RMQ
皆可。两种代码都贴上:又是空间换时间。。
·
2015-11-11 16:07
poj
上一页
17
18
19
20
21
22
23
24
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他