Contest page

A

Tag:贪心


猜想段的长度只会有$1$和$2$(感性理解,应该可以反证……),然后就可以DP/贪心了

B

Tag:贪心、组合


考虑如何构造合法方案。从右往左考虑球,因为当前球的位置相比于其他未考虑的球靠右,所以它要尽可能产生负贡献(成为三元组的$a$),否则尽可能产生$0$贡献(成为三元组的$b$)。


产生负贡献的条件是存在其他两种颜色的球构成的二元组,产生$0$贡献的条件是存在一种其他颜色未组成二元组的球。在产生$0$贡献时当前球可以选择一个未组成二元组的球形成二元组,此时对答案有"未形成二元组数量的球"的贡献;而产生负贡献时则对答案有“二元组数量”的贡献。


将所有贡献乘起来再乘上$N!$就是答案。

C

Tag:构造


考虑最后一次操作,因为操作是将数字变为当前数字和相邻数字之和,而数都是正的,所以最后一次操作的结果一定会比相邻两个数要大。


所以考虑倒着做,每一次选择当前$B$序列中不满足$A_x = B_x$的最大值位置$x$,它一定满足比相邻两个位置的值之和大,否则无解。找到这个位置之后我们认为最后若干次操作在$x$上进行,然后进行若干次逆操作直到$A_x = B_x$或者$B_x B_x$则无解,否则统计逆操作次数即为答案。

D

Tag:构造、二分图匹配


题目等价于:设$b_{i,j} = \lfloor\frac{a_{i,j} - 1}{M} \rfloor$,需要重排行使得$b$的每一列是一个$0$到$N-1$的排列。


不难证明将某一列安排为$0$到$N-1$的排列之后删去这一列,剩余的$b_{i,j}$矩阵也有解。所以我们按列去做。不难发现这是一个行和数字的匹配问题,Dinic/匈牙利即可构造出一种方案。


最后我们按照$b_{i,j}$的顺序排列$a_{i,j}$就可以得到第一次输出的矩阵,然后按照$b_{i,j}$从小到大对列进行排序即可得到第二次输出的矩阵。

E

Tag:贪心


考虑初始的$S$中字典序最小的字符$x$。我们希望$x$在开头出现得尽可能多。


设初始的$S+rev(S)$中最长的$x$连续段长度$L$,则最后的串的前缀$x$长度一定可以构造为$\min\{N , 2^{K-1}L\}$,因为我们可以将$S+rev(S)$的$L$个连续的$x$放在$S'$末尾,就可以每一次倍长$x$连续段长度,最后把这个连续段放在$S'$的最前面即可。


对于$2^{K-1}L \geq N$的情况直接输出$N$个$x$,否则枚举所有可能的$S+rev(S)$的子串,可以$O(N)$得到进行上述做法之后得到的串。因为有$O(N)$个这样的子串,所以复杂度是$O(N^2)$的。

F

Tag:构造


我们称一个串$S$是好的当且仅当存在$k$满足:$S$满足$(k,l)$。我们先考虑判断一个串$S$是否是好的。考虑如下做法:


1、如果串长为$1$那么一定满足;如果串中只存在一种数字,则串$S$是好的当且仅当$|S| \geq L$;


2、否则考虑其中的最小值$min$,并设$S$中下标在$[l_1,r_1]\cup[l_2,r_2] \cup ... \cup [l_k,r_k](\forall i \in [2,k] , r_i > l_i + 1)$内的所有位置的值均为$min$。


3、考虑其中所有的区间$[l_i,r_i]$,如果$r_i - l_i + 1

对于操作3的正确性可以这样理解:对于区间$[l_i,r_i]$,在接下来划分的过程当中,这个区间划分出来的所有子区间长度至少为$L$,否则当做到$(min+1,L)$的时候当前串是不好的。所以这$r_i - l_i + 1$个$min$可以等价为$\lfloor \frac{r_i - l_i + 1}{L} \rfloor$个$min + 1$。用$set$维护整个序列,不难得到序列中出现过的数的总数是$O(n)$级别的,所以复杂度为$O(nlogn)$。


然后考虑原问题。不妨拓展整个问题,变为:有两个长度为$|S|$的数组$L_i , R_i$,你需要求出$\sum\limits_i \sum\limits_j L_iR_j [S_{i,j}\ is\ good]$。原问题显然是拓展问题的$L_i = R_i = 1$的情况。对于这个问题,与上面的做法类似:


1、如果串中只存在一种数字,可以前缀和$O(n)$计算答案;


2、否则考虑其中的最小值$min$,并设$S$中下标在$[l_1,r_1]\cup[l_2,r_2] \cup ... \cup [l_k,r_k](\forall i \in [2,k] , r_i > l_i + 1)$内的所有位置的值均为$min$。


3、考虑其中所有的区间$[l_i,r_i]$,计算左右端点在$[l_i,r_i]$内的答案,并将$[l_i,r_i]$内的所有$min$替换为$\lfloor \frac{r_i - l_i + 1}{L} \rfloor$个$min + 1$,更新$LR$数组,然后回到操作$1$。


问题是如何更新$LR$数组。我们举题解中的例子来解释(因为真的不好直接讲啊QAQ):


考虑序列$1\ 1\ 1\ 1\ 1\ 1\ 1\ 1\ 1\ a\ b\ c\ d\ e$,其中$a,b,c,d,e>1$,$L=3,min=1$。那么接下来序列会缩成$2\ 2\ 2\ a\ b\ c\ d\ e$。考虑新序列的串$2\ 2\ a\ b\ c$,它可以对应原序列中$\underbrace{1\ 1\ ...\ 1}_{6 \sim 8\text{个}1}\ a\ b\ c$,因为这样的串可以通过上述操作变为$2\ 2\ a\ b\ c$。这意味着$L'_2 = L_2 + L_3 + L_4$。其余的$LR$是类似的。


总复杂度和上面一样是$O(nlogn)$的。有一些细节:1、对于3操作中新加入的数字段,需要把左右端点在这个数字段内的贡献减掉避免重复;2、注意$r_i - l_i + 1

AGC037的更多相关文章

  1. AGC037 C Numbers on a Circle【思维】

    题目传送门 题意 这道题被某大佬改编拿来出成考试题,是长这个样子的: 好的,其实这才是真正的题意: 给定初始序列和最终序列,每次选择一个数变成自己和相邻2个数的和.问初始序列是否可以变为最终序列,若可 ...

  2. @AGC037 - E@ Reversing and Concatenating

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一个长度为 N 且只包含小写字母的字符串 S ,你可以执行 ...

  3. AtCoder Grand Contest 036

    Preface 这篇已经鸽了好久的说,AGC037都打完了才回来补所以题目可能都记不大清楚了,如有错误请指正 这场感觉难度远高于上一场,从D开始就不会了,E没写(看了题解都不会写),F就是抄曲明姐姐的 ...

  4. 【做题记录】AtCoder AGC做题记录

    做一下AtCoder的AGC锻炼一下思维吧 目前已做题数: 75 总共题数: 239 每一场比赛后面的字母是做完的题,括号里是写完题解的题 AGC001: ABCDEF (DEF) AGC002: A ...

  5. AtCoder AGC037D Sorting a Grid (二分图匹配)

    题目链接 https://atcoder.jp/contests/agc037/tasks/agc037_d 题解 这场D题终于不像AGC032D和AGC036D一样神仙了-- 还是可做的吧 虽然考场 ...

  6. OI知识点/得分技巧的归纳总结

    网络流 拆点/拆边技巧 题目来源 bzoj1070 题目描述 同一时刻有\(N\)位车主带着他们的爱车来到了汽车维修中心.维修中心共有\(M\)位技术人员,不同的技术人员对不同 的车进行维修所用的时间 ...

随机推荐

  1. ssl 原理简介

    要想弄明白SSL认证原理,首先要对CA有有所了解,它在SSL认证过程中有非常重要的作用.说白了,CA就是一个组织,专门为网络服务器颁发证书的,国际知名的CA机构有VeriSign.Symantec,国 ...

  2. Python 元编程

    1.为函数添加包装器 总是存在这样的场景,在一个函数执行前后需要做一些操作处理,常见于日志创建.权限认证或者性能分析等.但有一个问题存在,那就是被装饰的函数,其元信息会丢失,函数引用会指向装饰器的返回 ...

  3. 提前体验让人"回归Windows怀抱"的Windows Terminal

    前言 在一年一度的微软开发者大会Build 2019登场的Windows Terminal饱受好评,大家对其也是充满了兴趣和热情,程序员的朋友圈都被微软发布的最新终端 windows Terminal ...

  4. 淘宝接口-IP返回运营商

    #!/usr/bin/evn python# -*- coding:utf-8 -*-import jsonimport urllib2import datetimeimport reimport Q ...

  5. 在Asp.Net Core 3.0中如何使用 Newtonsoft.Json 库序列化数据

    在.Net Core 3.0中 内置了一套Json序列化/反序列化方案,默认可以不再依赖,不再支持   Newtonsoft.Json. 但是.NET Core 3.0 System.Text.Jso ...

  6. [Web] How to Test React and MobX with Jest

    转载自: https://semaphoreci.com/community/tutorials/how-to-test-react-and-mobx-with-jest?utm_content=bu ...

  7. tornado多进程模式不同进程写不同日志

    #coding: utf- ''' Author: Time: Target: ''' import logging import logging.handlers import os import ...

  8. Electron 打开开发者工具 devtools

    转载:http://newsn.com.cn/say/electron-devtools.html 在electron开发的过程中,可以用代码控制打开自带chrome的devtools开发者工具,进而 ...

  9. mvn命令修改pom打包的版本号

    在java项目中打包经常需要修改镜像的版本号.可以使用如下命令 mvn versions: // 如果要打包使用人如下命令,打印详细信息使用 -X mvn clean deploy -e -Dskip ...

  10. 华为交换机在Telnet登录下自动显示接口信息

    因为用console连接交换机,默认是自动显示接口信息的,比如down掉一个接口后,会自动弹出接口被down掉的信息,但是在telnet连接下,默认是不显示这些信息的,需要开启后才可显示. 1.首先开 ...