LA3971 Assemble

题意

请参考LRJ白书第一章例题11

思路

二分答案。

典型的“最小值最大问题”,考虑二分答案,检查一次二分的时间是可以接受的,因此本题得到解决。

代码

 

UVa 10795 A Different Task

题意

可以参考LRJ大礼包白书第一章例题11

和汉诺塔游戏一样的规则,区别是这个问题会给出多达60个圆盘每一个最开始在哪根柱子上,要你求出从这个局势开始到终盘(00n)最少要移动多少次。

思路

大概是个。。。构造题?

思路比较复杂,而且还涉及传统汉诺塔问题的结论(把一根有k个盘子的堆移到一个空柱子上,需要((2^k)-1)步)。

具体的思路可以参考白书P27.

代码

UVa 11384 Help is needed for Dexter

题意

请参考LRJ白书第一章例题10

思路

试验小数据,找规律。

代码

 

UVa 11464 Even Parity

题意

请参考LRJ白书第一章例题7.

思路

大概是个带有机智成分的枚举。

为什么这么说,因为这道题的关键思路点就是发现只要知道第一行,就可以构造出整个数表,这样我们只要枚举第一行就可以解决问题,复杂度直接降低了一次幂。

代码

 

 

UVA 10881 Piotr's Ants

题意

请参考LRJ白书第一章例题5

思路

两个蚂蚁相遇会马上调换方向,从视觉上看其实相当于擦身而过(虽然两只蚂蚁的身份并没有交换)。就像在物理中,两个质量相等的小球发生完全弹性碰撞,交换速度。这里是本题第一个思路点。

无论在任何时候,第i只蚂蚁永远是第i只蚂蚁,因为上面也说了,只是视觉上的擦身,实际上蚂蚁又各自回去了。这是第二个思路点。在这个地方还有一个问题,那就是可能会以为仅仅是位置关系保持原来的顺序,其实方向关系也是保持原来的顺序的,这样就可以解决蚂蚁的最终状态的判定问题。

这样我们就有了解法:首先利用擦身而过的想法,求出最终所有蚂蚁的分布。然后利用标号守恒的想法,把终止状态和起始状态对应。

代码

 

LA 3708 Graveyard

题意

请参考LRJ白书第一章例题4.

思路

大概是构造题。

跟白书不太一样的解法,贪心地把两种方案的一个顶点对在一起,然后逐个检查,取两种方案的最小角度差,加在一起,就是答案。

代码

 

UVa 11300 Spreading the Wealth

题意

请参考LRJ白第一章例题3

思路

大概是个构造题。

解决的方法是把整个题转化成一个方程组,令每个人手里的初始金币数量为Ai(已知),送出数量Xi,受付数量Yi,最终每个人金币数量M(已知),这样得到由若干形如Ai-Xi+Yi=M方程组成的方程组,当所有方程形式一样时,考虑逐个联立消去未知量,最终得到了关于X1和Xi的若干等式(注意到Xi和Yi+1的相等关系),我们的目标是令Xi之和最小,我们把所有Xi加在一起,就得到了一个仅关于X1的和式。

这个和式的形式可以几何表示是求数轴上一个点,使得其与若干已知点距离之和最短,这个问题的解取在中位数,这样本问题就可以解决了。(中位数是解的想法在白书上有详细的证明,使用反证法)

综合来看,本体需要适当转化,数学变形,数形结合。

代码

 

UVa 11729 Commando War

题意

请参考《LRJ大礼包::白》第一章例题2

思路

大概是贪心。

只要交代了任务,部下自己就会给做完了,基于这样的题意我们就可以设计这样的一种贪心策略:优先考虑完成任务时间长的,这样交代完了之后就会有更多的时间可以一边交代任务一边有人完成任务,更有效率。

具体操作就是把完成任务时间从大到小排个序,然后顺着检查一遍。

这个策略的证明在白书上面有提供,大概的证明套路就是说明不用这个策略时得到的答案不会更优,在证明时分类讨论了两种情况。

代码

 

 

 

UVA 12946 Peanoland contacting Gaussland

题意

给出了一个从整数到复数的映射,你要求出给你的整数映射成的复数的实部和虚部。

思路

STL complex裸题。

直接模拟就好,当然自己写一个complex结构体也不是难事。

代码

 

UVA 12955 Factorial

题意

给出你一个数,问你这个数最少能用多少个数(可以重复)的阶乘表示出来。

思路

使用一种简单的贪心策略:

从一个刚好比给出的数小的阶乘开始,不断尝试减掉较大的阶乘,直到将给出的数减为0 。

这个贪心策略是合理的,因为如果我们当前可以减掉n!,我们减掉(n-1)!一定不如减掉n!优,因为n!=n*(n-1)!,相当于我们多减了n次,所以我们要减掉n!才能保证最优。

代码

 

Scroll to top