贪心的方法做,现找出用原始材料能做的汉堡,在对多出来的材料进行贪心,把少的用钱买上,如果没钱了,就输出,如果有钱就没有多出来的了,可以直接买了
1 | #include<cstdio> |
对汉堡进行二分答案,如果花的钱多了就买少点,少了就买多点
1 | #include<cstdio> |
贪心的方法做,现找出用原始材料能做的汉堡,在对多出来的材料进行贪心,把少的用钱买上,如果没钱了,就输出,如果有钱就没有多出来的了,可以直接买了
1 | #include<cstdio> |
对汉堡进行二分答案,如果花的钱多了就买少点,少了就买多点
1 | #include<cstdio> |
很容易想到的一个思路是暴力,就是对多的蛋糕吃,进行bfs();一旦两种蛋糕相等,就是最小步数的,很容易写。注释掉的代码就是还有更好的方法,很容易看出,最后的解一定是它们的最大公约数,然后把他们的最大公约数去掉,看看能不能吃成1,记下步骤,也可以看能不能吃成最大公约数,是一样的。12345678910 …
二分+前缀和优化,不优化就是o(nmlogn)了对参数w进行二分答案,通过w对y进行计算,如果找大了,就说明参数w找小了,答案在mid右面,找小了反之。12345678910111213141516171819202122232425262728293031323334353637383940414 …