AT_abc106_d [ABC106D] AtCoder Express 2 题解

Posted Ggsddu_zzy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AT_abc106_d [ABC106D] AtCoder Express 2 题解相关的知识,希望对你有一定的参考价值。

题目传送门

解题思路

区间 \\(dp\\)

划分阶段:以左右城市之间的列车数量为阶段。

状态表达:设 \\(f_i,j\\) 为城市 \\(i\\) 与城市 \\(j\\) 之间的列车数量。

状态转移:

由图可知,城市 \\(l\\) 与城市 \\(r\\) 之间的列车数量,就是城市 \\(l\\) 与城市 \\(r-1\\) 之间的列车数量与城市 \\(l+1\\) 与城市 \\(r\\) 之间的列车数量(蓝色括号)加上刚好从城市 \\(l\\) 到城市 \\(r\\) 的列车数量,但是还有一个重合部分,也就是城市 \\(l+1\\) 与城市 \\(r-1\\) 之间的列车数量(橙色方框)。

所以,城市 \\(l\\) 与城市 \\(r\\) 之间的列车数量就等于城市 \\(l\\) 与城市 \\(r-1\\) 之间的列车数量与城市 \\(l+1\\) 与城市 \\(r\\) 之间的列车数量减去城市 \\(l+1\\) 与城市 \\(r-1\\) 之间的列车数量加上刚好从城市 \\(l\\) 到城市 \\(r\\) 的列车数量。

即:

\\[f_i,j=f_i,j+f_i,j-1+f_i+1,j-f_i+1,j-1 \\]

初始状态:求出刚好从城市 \\(i\\) 到城市 \\(j\\) 的列车数量;即:f[l[i]][r[i]]++;

求解目标:\\(f_p,q\\)

代码

AC 记录

#include<bits/stdc++.h>
#define ri register int
using namespace std;
int n,m,q; 
int l[200005],r[200005],f[505][505];
int main()
	cin>>n>>m>>q;
	for(ri i=1;i<=m;i++)
		cin>>l[i]>>r[i];
		f[l[i]][r[i]]++;
	
	for(ri i=1;i<=n;i++)
		for(ri j=1;j<=n;j++)
			f[i][j]+=f[i+1][j]+f[i][j-1]-f[i+1][j-1];
	while(q--)
		int u,v;
		cin>>u>>v;
		cout<<f[u][v]<<\'\\n\';
	 
	return 0;

SQL Server:SQL Like 通配符特殊用法:Escape

%:匹配零个及多个任意字符; _:与任意单字符匹配; []:匹配一个范围; [^]:排除一个范围 ;-:连字符

Symbol Meaning
like ‘5[%]‘ 5%
like ‘[_]n‘ n
like ‘[a-cdf]‘ a, b, c, d, or f
like ‘[-acdf]‘ -, a, c, d, or f
like ‘[[]‘ [
like ‘]‘ ]
like ‘abc[
]d%‘ abc_d and abc_de
like ‘abc[def]‘ abcd, abce, and abcf
like ‘[^1-9]‘ 0
like ‘[^1-9b-z]‘ 0, a

对于字符串中出现的特殊字符:‘%‘,‘[‘,‘[]‘, ‘_‘ 可以使用 ‘[]‘ 把它们包含起来,这样在匹配模式(pattern)中,它们就被当作普通字符对待了。

  1. 用 like ‘[[]‘ 匹配特殊字符 ‘[‘

select 1 where ‘[ABCDE‘ like ‘[[]%‘

  1. 用 like ‘]‘ 匹配特殊字符 ‘]‘

select 1 where ‘]ABCDE‘ like ‘]%‘

  1. 用 like ‘[[]]‘ 匹配特殊字符 ‘[]‘

select 1 where ‘[]ABCDE‘ like ‘[[]]%%‘

  1. 用 like ‘[]‘ 匹配特殊字符 ‘

select 1 where ‘ABCDE‘ like ‘[]%‘

  1. 用 like ‘[%]‘ 匹配特殊字符 ‘%‘

select 1 where ‘ABC%DE‘ like ‘ABC[%]DE‘

对于其他的特殊字符:‘^‘, ‘-‘, ‘]‘ 因为它们本身在包含在 ‘[]‘ 中使用,所以需要用另外的方式来转义,于是就引入了 like 中的 escape 子句,另外值得注意的是:escape 可以转义所有的特殊字符。

复制代码
select 1 where ‘^ABCDE‘ like ‘!^ABCDE‘ escape ‘!‘
select 1 where ‘-ABCDE‘ like ‘!-ABCDE‘ escape ‘!‘
select 1 where ‘]ABCDE‘ like ‘!]ABCDE‘ escape ‘!‘

select 1 where ‘%ABCDE‘ like ‘%ABCDE‘ escape ‘‘
select 1 where ‘%ABCDE‘ like ‘!%ABCDE‘ escape ‘!‘
select 1 where ‘%ABCDE‘ like ‘#%ABCDE‘ escape ‘#‘
select 1 where ‘%ABCDE‘ like ‘@%ABCDE‘ escape ‘@‘

select 1 where ‘[ABCDE‘ like ‘![ABCDE‘ escape ‘!‘
select 1 where ‘]ABCDE‘ like ‘!]ABCDE‘ escape ‘!‘
复制代码

看出规律了吧,就是用 escape 后面紧跟着的字符来做转义字符。 escape 后面的字符相当于 C 语言字符串中的转义字符 ‘‘。

最后,看一个更加复杂的匹配,注意“-”这个也是特殊字符也需转义。

select 1 where ‘[^A-Z]ABCDE‘ like ‘[^A-Z]%‘ escape ‘‘

后记:用过正则表达式的朋友应该都知道,在正则表达式里可以用表示匹配0次或是多次, [u4e00-u9fa5]这个可以匹配中文,但在这里我没有发现类似的功能,所以匹配一些复杂的语句就比较头疼。如我要匹配形如:印张数量单价、200+印张数量单价、印张数量,但不匹配形如:印张数量5单价、印张数量6767、55印张数量uu的数据就很难实现了。

下面这个就是要匹配包括“纺梦”这两个字,但这两个字只能是与“+-*/”这四个字符相连或是单独存在。如果这里的“纺梦”是任意中文字符就没办法去处理了。

复制代码
create table #tbl(n int,v nvarchar(100))
insert into #tbl
select 1,‘1+纺梦1+2‘
union select 2,‘1+纺梦+1‘
union select 3,‘纺梦‘
union select 4,‘纺梦+1‘

select * from #tbl
where (v like ‘%[+-/]纺梦[+-/]%‘ ESCAPE ‘‘)
or (v like ‘纺梦[+-/]%‘ ESCAPE ‘‘)
or (v like ‘%[+-
/]纺梦‘ ESCAPE ‘‘)
or (v = ‘纺梦‘)

--select * from #tbl
drop table #tbl






























以上是关于AT_abc106_d [ABC106D] AtCoder Express 2 题解的主要内容,如果未能解决你的问题,请参考以下文章

AT_abc_264_g

AT_abc271_e 总结

AT_abc139f 题解

atc abc159FF - Knapsack for All Segments(dp优化)

ARC106 选做

ABC291题解(D-G)