JSOI2015 day1

JSOI2015 day1

题目和官方题解:点击打开链接

t1:
题目大意 设全集为1个拥有n个数的集合,现在把全集的子集填入k行的三角形中,其中三角形第i行有i列(有点像杨辉三角).
要求对于i行j列填入的子集f[i][j],必须使得f[i][j]为f[i-1][j]的子集,同时也要是f[i][j+1]的子集.(当f[i][j]==f[i-1][j]这种情况发生时也认作合法).
给出n和k,求方案数mod(1e9+7).
(n,k<=10^9)
思路:
想都没想就深搜打了一个4x4的表,发现答案就是2^(n*k)....开心.
然而这到底怎么做的呢?

t2:
题目大意 有n个物品,每个物品有不同的值A[i],允许从中选出连续的一段物品(长度在l到r之间,l,r由题中给出.)
最大化(max(A[i]...A[j])-min(A[i]...A[j]))/(j-i+k).
(i到j为选出的区间).k是题目给出的常数.

(n<=50000)

思路:分数规划(其实这是什么鬼我不知道....)只打了一个暴力.

t3:
题目大意 给出一棵树,每一条树边上有一个字符串,每次询问给出a,b,一个字符串s,询问a到b路径上有多少条边上的字符串以s为前缀.
(n,q<=10^5,所有字符串的长度<=10)

思路:
可持久化trie裸题.
倒是我自己yy了一种算法(卡hash好不容易A了...)对于每一条边上的字符串把它所有的前缀都hash下来存在以root[]为根的权值线段树中,询问的时候树链剖分+权值线段树前缀和相减就可以了.


你可能感兴趣的:(JSOI2015 day1)