这一道题,我也是搞了很久才搞懂的(也就两个多小时). 感谢Rayment大佬的题解! 我们进入正题. 对于一个笼子里的动物,我们可以选择撤走或不撤走,可以用0和1来表示,很容易就想到二进制,想到状压dp(为什么先选dp,看数据想想吧). 观察题面,我们可以发现,小朋友最多可达五万人(动物园容得下吗...)!太大了,肯定不能来做状压dp. 不过,正当我们努力寻找更小的可以用来状压dp变量时,去忽略了题面上的一点: 每个小朋友站在大围栏圈的外面,可以看到连续的 5 个围栏 5,这个数字很小,可以用来…