0%

1
2
3
4
5
FileInput = False

if FileInput:
sys.stdin = open('flower.in', 'r')
sys.stdout = open('flower.out', 'w')

李白打酒加强版

https://www.lanqiao.cn/problems/2114/learning/

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# n酒店,m花
n, m = map(int, input().split())
dp = [[[0 for k in range(m + 1)] for j in range(m + 1)] for i in range(n + 1)]
# dp[i][j][k] 遇到i个酒店j个花后剩余k酒量的方案数
dp[0][0][2] = 1
# dp[1][0][4] = 1
# dp[0][1][1] = 1
# dp[0][2][0] = 1

for i in range(0, n + 1):
for j in range(0, m + 1):
for k in range(m + 1):
if j == m and i != n: # 不能没花了但酒店还有
continue
if not k & 1 and i > 0: # 现在这一个是酒店,i减1,k是一半
dp[i][j][k] += dp[i - 1][j][k // 2]
if k != m and j > 0:
dp[i][j][k] += dp[i][j - 1][k + 1]

print(dp[n][m][0] % 1000000007)
阅读全文 »

最长公共子序列

dp[i][j],A序列前i个和B序列的前j个的最长公共子序列。

最长递增序列(蓝桥骑士)

阅读全文 »

分组背包

问题:每一组当中的物品只能选一个。

方法:在0/1背包的基础上,在每一组中遍历所有物品。

阅读全文 »