对于 n n n个数,其中有 ⌈ n 2 ⌉ \lceil \frac{n}{2} \rceil ⌈2n⌉个奇数。对于这 n n n个数,都可以表示为 a × 2 k a\times 2^k a×2k这种形式。其中, k ≥ 0 k\geq 0 k≥0, a a a为奇数且 a ≤ n a\leq n a≤n。我们从中取出 ( ⌈ n 2 ⌉ + 1 ) (\lceil \frac{n}{2}\rceil +1) (⌈2n⌉+1)个数字,将它们表示成上述的形式,根据鸽笼原理,那么其中一定有两个数具有相同的 a a a,那么这两个数可以表示成 a × 2 p a\times 2^p a×2p和 a × 2 q a \times 2^q a×2q,那么一个数必定是另一个数的因数。
接下来,如果我们选择$\lceil \frac{n}{2}\rceil 个 数 , 如 果 我 们 现 在 选 择 最 大 的 个 个数,如果我们现在选择最大的个 个数,如果我们现在选择最大的个\lceil \frac{n}{2} \rceil 数 , 这 时 候 , 对 于 每 一 个 数 数,这时候,对于每一个数 数,这时候,对于每一个数b , 与 它 最 接 近 的 并 且 是 它 因 子 的 数 ,与它最接近的并且是它因子的数 ,与它最接近的并且是它因子的数\frac{b}{2}$一定在剩下的没有选择的数中。因此,选出这么多数是不成立的。
综上,答案为 ⌈ n 2 ⌉ + 1 \lceil \frac{n}{2} \rceil +1 ⌈2n⌉+1。
首先,我们可以观察到如下几个不难证明的性质:
接下来,可以手玩一些例子:
#和$
代表被染色的格子,$
是最后一个被染色的格子,.
代表未染色的格子,当前状态为下所示。
....
....
##$.
###.
先随便走一步
....
..$.
###.
###.
这时,受到命运的指引,我们接下来必须扩充一行。为什么呢?
如果接下来我下一步就是不去 A,跑到别的地方去玩。(如下:我们将 3 个未染色的格子标记成 ABC)
.B..
CA$.
###.
###.
那接下来要想给 A 染色我是不是必须到达 B,C 中的某个一个格子呢?等到那个时候… 完蛋了啊!!!
因此,我下一步必须去 A,下下步必须去 C。
于是,可以得出以下结论:
如果当前被染色的区域是个 r ( r ≥ 2 ) r(r \geq 2) r(r≥2) 行 c ( c ≥ 2 ) c(c \geq 2) c(c≥2) 列的矩形,那么接下来要么扩充成 r + 1 r+1 r+1 行 c c c 列的矩阵(扩充行),要么扩充成 r r r 行 c + 1 c+1 c+1 列的矩形(扩充列)。并且根据当前状态中最后一个被染色的格子在哪个角上,扩充行/列的方案都是唯一的。
从 1 ∗ 1 1*1 1∗1 的矩阵,到 n ∗ m n*m n∗m 的矩阵,一共要扩充 n + m − 2 n+m-2 n+m−2 次,其中有 n − 1 n-1 n−1 次是扩充行,这样的决策有 ( n + m − 2 n − 1 ) \binom{n+m-2}{n-1} (n−1n+m−2) 种,根据最后一个被染色的格子在哪个角上,方案数为 4 ∗ ( n + m − 2 n − 1 ) 4*\binom{n+m-2}{n-1} 4∗(n−1n+m−2)
Corner case: n = 1 n=1 n=1 或者 m = 1 m=1 m=1,小心特判掉即可。
用 d p [ i ] [ j ] [ k ] dp[i][j][k] dp[i][j][k]表示结尾是 ( i , j ) (i,j) (i,j) 且长度为 k k k的左端不能扩展的路径方案数,这里的 k k k最大为 4 4 4,我们初始化长度为 1 1 1的不能向左扩展的路径对应的状态,然后按照格子的权值从小到大的顺序 d p dp dp即可,最后累和方案数的时候注意判断路径是否可以往右扩展。
f ( c [ ] ) f(c[]) f(c[]) 表示,从“权值为 i i i 的点,恰有 c [ i ] c[i] c[i] 个被访问过”的状态出发,访问所有点,有几种方案。
首先枚举P在哪个边上,用叉积和点积来判断,如果确定了P在AB边上,然后就是求平分线PE,假设P离得A近,那么E一定落在BC上,我们以这种情况举例子,其他同理
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pE7egbeU-1575275555709)(C:\Users\黄敏聪\AppData\Roaming\Typora\typora-user-images\image-20191130122848970.png)]
解法1:
根据叉积算面积的方法, ∣ B A ∣ × ∣ B C ∣ × s i n B × 0.5 = ∣ B P ∣ × ∣ B E ∣ × s i n B |BA|\times|BC|\times sinB\times 0.5=|BP|\times|BE|\times sinB ∣BA∣×∣BC∣×sinB×0.5=∣BP∣×∣BE∣×sinB,直接算出 ∣ B E ∣ |BE| ∣BE∣进而求出点E
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DNYVo3HG-1575275555710)(C:\Users\黄敏聪\AppData\Roaming\Typora\typora-user-images\image-20191130123037020.png)]
解法2:
取AB中点D,则CD为一条平分线,连接PC,过点D做DE平行于PC交BC与点E,则PE即为平分线。
证明:可以证出下面红色部分两三角形面积相等然后有PEB的面积和BCD相等.