zoukankan      html  css  js  c++  java
  • The 2018 ACM-ICPC Asia Shenyang Regional Contest

    地址

    Rank Solved A B C D E F G H I J K L M
    --/-- 4/13 . . O . O . O . Ø O Ø . .

    O: 当场通过

    Ø: 赛后通过

    .: 尚未通过

    A Sockpuppets

    unsolved


    B Sequences Generator

    unsolved


    C Insertion Sort

    solved by chelly


    chelly's solution

    D Diameter of a Tree

    unsolved


    E The Kouga Ninja Scrolls

    solved by chelly&ch


    chelly's solution

    首先曼哈顿距离转成切比雪夫距离,于是x坐标和y坐标就独立出来了
    问题转化成了,有n个位置,每个位置有一个数字和一个颜色,修改可以改变一个位置的数字或者颜色,询问[l,r]内相差最大的不同颜色数字
    ch提出了可以用线段树维护区间的最大值 与最大值颜色不同的次大值 最小值 与最小值颜色不同的次小值

    F Counting Sheep in Ami Dongsuo

    unsolved


    G Best ACMer Solves the Hardest Problem

    solved by chelly


    chelly's solution

    注意到坐标范围很小,并且因为都是整点,所以距离一个整点欧几里得距离恰好为(sqrt{K})的整点个数并不会很多,打个表发现,顶多会有48*4个
    所以对于每个操作就可以暴力了,可以用二维数组存下整个图
    注意清空二维数组时候的技巧

    H Rainbow Graph

    unsolved


    I Distance Between Sweethearts

    upsolved by chelly


    chelly's solution

    如果权值式子没有前面那一坨max,后面显然可以异或卷积维护,直接FWT
    现在考虑前面的max取值,显然只有0~2000,我们可以枚举前面最大值的取值,然后后面做一次FWT,这样只需要做2000次的FWT,时间复杂度是可以接受的
    如果我们枚举每个最大的取值,会发现右边三个数组的初值很难界定,我们可以这样做:

    • 求出max<=k情况下的三个数组初值,然后fwt得到它们的异或卷积,于是我们知道了当max<=k的时候,对于右边六个数字异或出来的异或值,各自都有多少种方案
    • 求出max<k情况下的三个数组初值,然后fwt得到它们的异或卷积,于是我们知道了当max<k的时候,对于右边六个数字异或出来的异或值,各自都有多少种方案
    • 将上面两个结果的对应位置相减,于是就知道max=k时候右边六个数字异或出来的异或值,各自都有多少种方案

    至于“max<=k情况下的三个数组初值”,可以在“max<=k-1情况下的三个数组初值”基础上加上数字差恰好为k的pair得到

    J How Much Memory Your Code Is Using?

    solved by chelly


    chelly's solution

    模拟一下

    K Let the Flames Begin

    upsolved by Feynman1999

    首先,对于经典的约瑟夫环问题,我们记(f(n,m))表示初始有(n)个人,第(m)个出队的人是谁(从0号开始报数)。则有递推式(f(n,m)=(f(n-1,m-1)+k) \% n) 其中(k)表示每报数(k)次一个人出队,注意编号从0开始

    递推式的证明: 考虑现在有(n)个人围成一圈,然后从0开始报数。假设第一个出队的人是(x) ,这时还有(n-1)个人,我们从刚刚出去的那个人的下一个人从0重新编号,那么以当前局面重新开始,第(m-1)个出队的人是初始所求的同一个人,但编号不同,差多少呢?即(f(n,m)=(f(n-1,m-1)+k) \% n) 。 +1 -1 细节手玩一下。

    回到本题,由于(m,k)可能会很大,但不会同时很大,当(m)较小的时候((m<=k)),直接递推即可。

    下面考虑(m>k)的情况,会发现模数大部分情况下远大于(k),也就是说可以用乘法代替多次加法,这样可以降低时间复杂度。具体代替多少次呢?考虑(f(a,b)=ans), 假设代替(x)次,则(f(a+x,b+x) = ans+x*k) 进行取模的等价条件是(ans+x*k > =a+x),即(x>=frac{a-ans}{k-1}) 即代替次数确定了(整除不整除,快加到(m)了等细节注意一下即可)。

    时间复杂度 (O(感觉能过))


    L Machining Disc Rotors

    unsolved


    M Renaissance Past in Nancy

    unsolved

    Replay

    本场是由chelly,ch,Feynman1999打的
    开始chelly找到了签到题J,于是写掉;ch开了K题约瑟夫,于是chelly把大白书丢给ch,ch学到了约瑟夫环的递推解法之后觉得可以魔改一下,于是上机;此时Feynman在跟榜读题。
    ch的K题写的是递归,一直RE;Feynman告知chelly C题题意,chelly于是想C,Feynman去读其它题;随后chelly一直卡在C的计数,ch一直卡在K,陷入江局= =。
    过了一段时间后,chelly想出了C题的做法,于是切掉,了解了G题之后,想了一会发现可以暴力,于是暴力莽了过去;ch成功放弃了K;
    接下来三人一起讨论E题,chelly提出可以先转成切比雪夫距离使得问题简化,然后ch提出可以用线段树维护最大次大最小次小,于是chelly准备了一下上去码码码,在chelly码的同时,Feynman和ch讨论L题的几何,似乎讨论出了正解;
    chelly在还剩40分钟的时候过掉了E,于是ch上机敲几何,最后由于精度问题WA到终场QvQ;在临近结束的时候chelly和Feynman读了I题,发现是个傻比FWT+计数,比E好写多了TAT

  • 相关阅读:
    吊打XXX
    [CQOI2011]动态逆序对
    陌上花开
    【BOI2007】摩基亚Mokia
    [SCOI2008]奖励关
    最小生成树
    打表
    【中学高级本】倒酒
    整数合并
    韩信点兵
  • 原文地址:https://www.cnblogs.com/Amadeus/p/9944072.html
Copyright © 2011-2022 走看看