关注
第四题
其实是先看的第五题,回来看了半天没思路,想了想肯定会有方案数为0的情况,结果能过45%...
n, k = map(int, input().split())
a = [0] + list(map(int, input().split()))
1. dp[i][j] 表示枚举到数组前i位,删了j个数的方案数
2. 正难则反,用总方案数C(n, k)减去删除后不为倍数的方案, 算贡献
dp = [[0] * (k + 1) for _ in range(n + 1)]
MOD = 10 ** 9 + 7
now = 0
for i in range(n):
ok = 0
for j in range(n):
if i == j:
continue
else:
temp = math.gcd(a[i], a[j])
if temp == a[i] or temp == a[j]:
ok = 1
break
if ok:
if now < k:
dp[i][now + 1] *= dp[i - 1]
else:
if now < k:
dp[i][now + 1] = 0
print(dp[n][k])
注释是赛时的思路,但都没推出来,整份代码其实就是变着花样的print(0)
第五题
看着很有思路,一通乱敲,过样例了!好!提交!0%!遂怒,猜了个n/2看看能过多少,结果全过了,你这数据比上午的东子都水啊。。。
# 好像代码没存,总之硬模拟了一下
print(n // 2)
2
相关推荐
牛客热帖
更多
正在热议
更多
# 牛客AI体验站 #
18154次浏览 312人参与
# 记录实习开销 #
184573次浏览 813人参与
# 牛客新年AI问运 #
15659次浏览 173人参与
# 大家每天通勤多久? #
83600次浏览 678人参与
# 正在实习的你,几点下班 #
296994次浏览 2053人参与
# 牛客租房专区 #
154039次浏览 1602人参与
# 不给转正的实习,你还去吗 #
2626613次浏览 22896人参与
# 选择和努力,哪个更重要? #
191369次浏览 1497人参与
# 如何缓解入职前的焦虑 #
259746次浏览 1458人参与
# 我的岗位说明书 #
308077次浏览 2753人参与
# 有转正机会的小厂实习值得去吗? #
1147次浏览 22人参与
# 金融银行求职进展汇总 #
309657次浏览 1686人参与
# 你小时候最想从事什么职业 #
154175次浏览 2059人参与
# 校招入职后的感受 #
488384次浏览 3682人参与
# 入职第一天 #
47559次浏览 554人参与
# 投递无反馈,如何优化求职策略? #
8696次浏览 43人参与
# 工作后会跟朋友渐行渐远吗 #
60275次浏览 415人参与
# 你最讨厌面试被问什么 #
2088次浏览 30人参与
# 牛友们,签完三方你在忙什么? #
137596次浏览 997人参与
# 帆软软件工作体验 #
14713次浏览 86人参与
OPPO公司福利 1216人发布
查看10道真题和解析