2021-08-09

博客内容涉及了几何算法、图论问题和动态规划在编程挑战中的应用。第一部分介绍了如何通过数学方法解决倒酒问题。第二部分讨论了一种寻找最小生成树的策略,涉及gcd计算和数学证明。第三部分探讨了预处理完全背包解决硬币购物问题的创新思路,揭示了多重背包问题的解决技巧。
摘要由CSDN通过智能技术生成

1.倒酒:一道裸的拓欧,复习一下板子

2.Golden Feather打表找规律,(题意是找一颗最小生成树,不是最短路),所以对于第n个点,若存在前面n-1个点中的一个与第n个点的gcd=1,则ans=n-1。因此,问题变为哪些数不符合该条件。而后就是数学证明,fn与fn-1,fn-2,...比较,筛出不符合条件的数

3.硬币购物:其实这道题挺巧妙的,这个数据就一直给我们提示,不可能多重背包暴力做,T飞了。所以一定是预处理好完全背包,再考虑怎么得到答案。然而我太蒻了想不出来,看完题解似乎看懂了,但是要自己推一边发现题解没有把思考步骤写下来。

①dp[i],因为需要预处理,所以表示选择前四个物品的完全背包,而又怎么与多重背包关联起来呢?我们发现每个物品i最多只能选di个,意味着第i个物品占(di+1)*ci个体积及以上是不可能的,而这个方案数就是dp[v-(di+1)*ci],把这个减掉就行了。

②但是这是否做了对集合枚举的不重不漏呢?答案是否定的,在保证第1件物品多用了的同时,无法保证其他物品没有多用,所以dp[v-(d1+1)*c1]实际上把第2件物品多用,第3件物品多用......包含进去了,用二进制来说就是1000,1001,1010,1011,1100,1101,1110,1111这几种状态

代码不难,思路确实有点新颖

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值