时间安排
7
:
50
−
8
:
20
7:50-8:20
7:50−8:20 把四道题都看了一遍,T1觉得是个dp,T2推了推样例,确定是不会写的题,T3多字符匹配很容易想到AC自动机,但是发现不会维护不重合的串的出现次数,T4应该要用数据结构写。
8
:
20
−
8
:
50
8:20-8:50
8:20−8:50 T1我最开始的想法是dp,先把数组从大到小排好序,然后设
f
i
,
j
f_{i,j}
fi,j 表示考虑前
i
i
i 个数,选了
j
j
j 个的最大的和,然后在
j
=
3
j=3
j=3 和
j
=
5
j=5
j=5 的时候特判一下转移,但是不太对,然后就在考虑贪心,发现
p
2
,
p
3
p_2,p_3
p2,p3 一定的相邻的两个数,因为这样能使两数加起来更大,对于
p
4
,
p
5
,
p
6
,
p
7
p_4,p_5,p_6,p_7
p4,p5,p6,p7 同理,所以我就想枚举一个,二分一个,但是还有一个
p
1
p_1
p1,如果还是枚举的话就到
n
2
l
o
g
n
n^2log\,n
n2logn 了,然后我推了推性质觉得7个数连在一起的时候更优,所以就只判断了连续的7个。
8
:
50
−
9
:
10
8:50-9:10
8:50−9:10 最开始的时候T2样例推出来,所以又去推了推样例,但我怎么都无法理解怎么样更优,为什么要一直要从
2
2
2 走到
4
4
4,然后觉得这道题肯定做不出来所以就放弃了。
9
:
10
−
10
:
30
9:10-10:30
9:10−10:30 对于T3,其实我的想法还是挺多的,首先有一个
t
t
t 肯定是从
t
t
t 的最后一个字符处分割,这样一定最优,所以答案实际上就是
t
t
t 在整个字符串中不重叠的出现了多少次,我先码了一个暴力的hash,然后就想到AC自动机,因为是多字符串的匹配,所以我就在考虑如何统计,但是我把样例的AC自动机画出来后发现很难来统计,因为AC自动机上的匹配如果失配直接就跳到了fail指针处,很容易统计重合的,但是不重合的就不好统计了。
10
:
30
−
11
:
20
10:30-11:20
10:30−11:20 看到T4的第一想法是个模拟,所以我就用set来暴力维护整个区间,我又想到维护
m
n
i
mn_i
mni 和
m
x
i
mx_i
mxi 表示第
i
i
i 个人在挑选的时候的最小值和最大值,然后考虑每次增加一个数的后果,统计差值维护答案即可。
11
:
20
−
11
:
50
11:20-11:50
11:20−11:50 又去搞了搞T3。
11
:
50
−
12
:
10
11:50-12:10
11:50−12:10 提交。