比赛地址

A

题意:给一个\(n*m\)的初始为白色的矩阵,一次操作可以将一行或一列染成
黑色,问至少染出\(k\)个黑点的最少操作次数。
\(n\),\(m\)<=100,\(k\)<=1e4

B

题意:有\(n\)条线段,用二元组\((x,len)\)表示,占据\([x-len,x+len]\)的位置。
问最多能选择多少条不相交的线段。
\(n\)<=1e5,\(x_i\),\(len_i\)<=1e9

C

题意:给定\(n\),\(k\),\(s\),构造一个序列\(a\),使得恰好有\(k\)个二元组\((l,r)\),\(\sum_{i=l}^{r} a[i]\) = \(s\)。
\(n\)<=1e5,0<=\(k\)<=\(n\),\(s\)<=1e9,\(a_i\)<=1e9

D

题意:有\(n\)张卡片,初始时每张卡片上面是\(a[i]\),下面是\(b[i]\)。一次操作可以交换相邻两张牌,
并将这两张牌翻转。最小化操作次数,使得上面的数组成的序列不降。
\(n\)<=18,\(a_i\),\(b_i\)<=50

E

题意:给定一个\(n\)点\(m\)边的无向图,每个点可以被染成黑色或白色,每条边可以指定一个[1,1e9]以内的权值。
找出一种染色和给定边权的方案,使得:
1.至少存在一个黑点,一个白点;
2.每个点到与其最近的颜色相异的点的距离为\(d_i\)。
\(n\)<=1e5,\(m\)<=2e5,\(d_i\)<=1e9

F

题意:有一个\(n*m\)的矩阵,初始时每个点都有一个颜色。
你可以对其进行任意次操作,每次操作可以任选一行(列),将这一行(列)的点全染成黑(白)色。
问共能操作出多少种不同的矩阵。答案对998244353取模。
\(n\),\(m\)<=10


题解

A

入门题。根据\(n\),\(m\)大小判断染行还是染列。
时间复杂度:\(O(1)\)

B

经典的贪心问题。将所有线段按右端点排序,直接扫一遍,维护一下当前选到的右端点就好。
时间复杂度:\(O(nlogn)\)

C

\(傻逼题\)。直接指定\(k\)点权值为\(s\),剩下的都为\(s+1\)就行。注意\(s\)=1e9需要特判。
时间复杂度:\(O(n)\)

D

\(n\)很小,引导我们可以用指数级别的复杂度做题。首先可以想到暴力枚举所有牌最后哪边朝上。
考虑如何判定一个方案是否合法,并判断其最小的移动步数。
我们将这个状态设为\(S\),它的第\(i\)位为1就代表它是\(b_i\)朝上,否则是\(a_i\)朝上。

step1

1的个数一定是个偶数。

step2

我们根据这个01序列,可以得到最终的一个无序序列\(C\)。将这个序列排序,现在要做的就是
找一个合法的匹配方案。
可能读者会有些疑惑:这里为什么还要判断是否合法呢?
考虑那个01序列的另外一层意义:如果某一位为1,那么这一位的这张牌就移动了奇数次,否则就是偶数次。
这个东西分奇偶讨论一下,用vector存一下所有\(c_i\)的所有出现位置,一一匹配就行。
由于\(C\)中可能有重复元素,最优策略就是原序列中左边的点尽量和排序后的\(C\)的左边的点匹配。这个是显然的。
这样,我们就相当于得到了一个排列\(P\),表示一种匹配方案。

step3

那么确定这个方案合法后,如何求出最少的移动步数呢?可以发现这就是这个排列的逆序对个数。把它算出来,更新答案。
时间复杂度:O(\(2^n\) \(\times\) \(n^2\))

E

考虑从何下手这个问题。
首先,我们肯定希望这个最短路尽量好求一些。最好是所有的匹配都是两点直接相连的。
当然事实确实是这样的。这里给出一个证明。
考虑反证法:如果存在一种匹配方案\(a->c\),\(b->c\),\(a\),\(b\)是黑点,\(c\)是白点,且这三点的连边情况是:\(a---b---c\)。
首先,如果\(b\)和\(c\)匹配,那么\(a\)不会和其他点匹配。

情况1

\(d_a\)<\(d_b\):显然这种方案是不合法的;

情况2

\(d_a\)>=\(d_b\):显然可以将\(b\)换成白点,\(c\)换成黑点(\(c\)不换也行,具体看情况)。
因此,若有解,一定存在一种匹配方案,使得所有点都和它直接相连的一个点匹配。
接下来,考虑这样的一个匹配过程:
一个节点\(A\)找到了另一个节点\(B\),与其匹配。那么那个节点\(B\)有两种选择:一是和\(A\)匹配,一是和其他节点匹配。
重点是,无论如何匹配,\(d_B\)一定大于等于\(d_A\)。
由此下去,一定有一个最终状态,节点\(B\)别无他选,只能和\(A\)匹配。我们发现了隐藏在题目中的单调性。
由此,我们得到了一个做法:先将所有节点按\(d_i\)从小到大排序,然后对于每个节点,
先找有没有与其直接相连的未被染色的点,且两者的\(d\)相同。若有,则两点互相匹配,若没有,再找一个已被染色的点,
与其匹配即可。若还没有,则无解。
注意一定要先找能互相匹配的点,因为一次可以染两个节点的色。
时间复杂度:\(O(nlogn+m)\)

F

待填坑~


代码

先咕在这里,等写完F再放吧~

atcoder Keyence Programming Contest 2020 题解的更多相关文章

  1. M-SOLUTIONS Programming Contest 2020 题解

    M-SOLUTIONS Programming Contest 2020 题解 目录 M-SOLUTIONS Programming Contest 2020 题解 A - Kyu in AtCode ...

  2. AtCoder AIsing Programming Contest 2020 D - Anything Goes to Zero (二进制,模拟)

    题意:给你一个长度为\(n\)的\(01\)串,从高位到低位遍历,对该位取反,用得到的十进制数\(mod\)所有位上\(1\)的个数,不断循环直到为\(0\),输出每次遍历时循环的次数. 题解:根据题 ...

  3. Atcoder Panasonic Programming Contest 2020

    前三题随便写,D题是一道dfs的水题,但当时没有找到规律,直接卡到结束 A - Kth Term /  Time Limit: 2 sec / Memory Limit: 1024 MB Score ...

  4. [AtCoder] NIKKEI Programming Contest 2019 (暂缺F)

    [AtCoder] NIKKEI Programming Contest 2019   本来看见这一场的排名的画风比较正常就来补一下题,但是完全没有发现后两题的AC人数远少于我补的上一份AtCoder ...

  5. [AtCoder] Yahoo Programming Contest 2019

    [AtCoder] Yahoo Programming Contest 2019   很遗憾错过了一场 AtCoder .听说这场是涨分场呢,于是特意来补一下题. A - Anti-Adjacency ...

  6. 【AtCoder】KEYENCE Programming Contest 2019

    A - Beginning 这个年份恐怕需要+2 #include <bits/stdc++.h> #define fi first #define se second #define p ...

  7. 【AtCoder】Dwango Programming Contest V题解

    A - Thumbnail 题意简述:给出N个数,找出N个数中和这N个数平均值绝对值最小的数 根据题意写代码即可= = #include <bits/stdc++.h> #define f ...

  8. Atcoder Yahoo Programming Contest 2019 简要题解

    A-C 直接放代码吧. A int n,k; int main() { n=read();k=read(); puts(k<=(n+1)/2?"YES":"NO&q ...

  9. HHKB Programming Contest 2020 D - Squares 题解(思维)

    题目链接 题目大意 给你一个边长为n的正方形和边长为a和b的正方形,要求把边长为a和b的正方形放在长度为n的正方形内,且没有覆盖(可以相邻)求有多少种放法(mod 1e9+7) 题目思路 这个思路不是 ...

随机推荐

  1. Codeforces_805

    A.当l == r时,肯定输出这个数就可以了,当存在两个或两个以上连续的数时,2肯定是最多的数,或最多的数之一. #include<bits/stdc++.h> using namespa ...

  2. tomcat-windows10环境搭建

    1.进入Tomcat官网Apache Tomcat® - Welcome! 2.根据操作系统选择合适的版本下载 zip用于windows操作系统, tar.gz用于unix和linux操作系统 Bin ...

  3. node基础 day1

    js为什么能在浏览器中运行 浏览器内部存在一个js解析器,解析ECMAscript 把引擎从浏览器中抽离出来,不再依赖浏览器,作为一个软件安装在电脑上,在命令行里面, 这个软件就是node node ...

  4. windows本地安装以及使用Jenkins

    首先保证本地已安装JDK,Jenkins是需要Java开发的,需要JDK运行环境,此处不提供,网上一大把. 一.Jenkin安装: 下载Jekins,到官网下载,https://jenkins.io/ ...

  5. C#在窗体中按下鼠标键拖动窗体

    [DllImport("user32.dll")]//拖动无窗体的控件 public static extern bool ReleaseCapture(); [DllImport ...

  6. Jenkins新建节点找不到通过Java web启动代理?

    参考博客:Jenkins新建节点,启动方式没有“通过Java Web启动代理”选项怎么办? 在Jenkins中,打开“系统管理”→“管理节点”→“新建节点”页面时,“启动方式”选项没有“通过Java ...

  7. 解释为什么wait()和notify(), notifyAll()要放在同步块中

    首先,wait()是释放锁的,因此wait()之前要先获得锁,而锁在同步块开始的时候获得,结束时释放,即同步块内为持有锁的阶段. 那为什么要设计同步块呢?或者说没有同步块会怎样呢?

  8. 广西Ukey登录需求

    1.前端控制浏览器用户安装证书[1.检测,2,提示用户强制安装] JITComVCTK_S.exe 2.前端调用接口获取认证原文 3.对前端认证原文处理,提交请求到后端 摘算法处理后的认证原文 认证原 ...

  9. C#设计模式学习笔记:(9)组合模式

    本笔记摘抄自:https://www.cnblogs.com/PatrickLiu/p/7743118.html,记录一下学习过程以备后续查用. 一.引言 今天我们要讲结构型设计模式的第四个模式--组 ...

  10. css3新增边框、阴影、边框、背景、文本、字体

    css3和css有什么区别?简单来讲css3是css(层叠样式表)技术的升级版本,css3新特征有很多,例如圆角效果.图形化边界.块阴影与文字阴影.使用RGBA实现透明效果.渐变效果.使用@Font- ...