D. Domino for Young

Posted 1024-xzx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了D. Domino for Young相关的知识,希望对你有一定的参考价值。

基本思想是利用涂色的方法,用黑白两种颜色把方格全部涂色,相邻方格不同色。

方法1:基于二分图匹配的思想

一开始也想过二分图匹配,但数据量太大,就放弃了这种想法。其实根据增广路的定义。如果白色的方格的数量小于黑色方格数量,那么当白色方格还没有匹配完时,一定有黑色的方格没有匹配。那么从该白色的方格出发,一定可以走出一条增广路到达黑色的方格。即数量少的颜色一定可以匹配完。那么只要求出二者数量的最小值即可。

技术图片
 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int N=3e5+5;
 4 int a[N];//把图涂成两种颜色: 黑和白
 5 int n;//求黑色和白色块的数量的最小值
 6 int main()
 7 {
 8     while(scanf("%d",&n)!=EOF)
 9     {
10        long long ans1=0,ans2=0;
11        int a;
12        for(int i=1;i<=n;i++)
13        {
14            scanf("%d",&a);
15            ans1+=(a/2);
16            ans2+=(a/2);
17            if(i&1)
18            {
19                if(a&1)
20                 ans1++;
21            }
22            else
23            {
24                if(a&1)
25                 ans2++;
26            }
27        }
28        printf("%lld
",min(ans1,ans2));
29     }
30     return 0;
31 }
View Code

方法2:

对于每一列,一列一列的放的话,那么如果该列的方格数量为偶数那么最后该列一定不剩下方格,如果为奇数,那么肯定会剩下一个,所以最终结果就是如果黑色和白色的方格数量不等的话,那么最后一定会剩下。且数量少的一定会被删除。

以上是关于D. Domino for Young的主要内容,如果未能解决你的问题,请参考以下文章

Leetcode: Minimum Domino Rotations For Equal Row

[LC] 1007. Minimum Domino Rotations For Equal Row

CF1210A Anadi and Domino

Educational Codeforces Round 76 (Rated for Div. 2) - D. Yet Another Monster Killing Problem(贪心)(示例代码

Deltix Round, Summer 2021 (open for everyone, rated, Div. 1 + Div. 2) D. Take a Guess (交互,位运算性质)(代码片

Lotus Domino Designer中的源代码控制