这些题目在BZOJ上面有,可惜是权限题。话说BZOJ上面的题目真的挺好的,要不是我穷,早就去弄个号了!

言归正传,今年的题目难度可以由一个名人名言看出:

题目太水。——某某神犇

可是我掂量了一下,发现如果自己去的话,估计就没什么好果子了。估计只能拿个\(100+10+40=150\)分了,: (。

异或运算

对于每个询问,最基本的思路就是从高位到低位确定答案(因为异或元素位与位之间不影响)。

举个例子,如果询问第\(k\)大,那么首先确定最高位,我们可以统计这个询问的矩形里面最高位是\(0\)个数字个数,假设是\(x\),那么如果\(x \leq k\),则最高位是\(0\),否则是\(1\)。如法炮制,我们就能算出这个答案了。

看数据范围,发现\(n\)和\(p\)非常小(这很容易萌生暴搞的想法),我们要做的是,求在询问矩形里,形如YYYYYXXX的数字的数量,其中Y表示答案的最高的已知的几位,X则是任意的\(0\)或\(1\)。由于\(n\)很小,这里我们可以把矩形拆成一行一行的横条状,我们分开统计每一行。

这样我们的问题就变为,在\(Y\)序列的某段区间里,形如ZZZZZXXX的数量,其中Z是对应的Y与\(X_i\)的异或值(\(i\)表示是第几行),X的含义同上。这样的话,我们可以排序然后二分,或者是使用可持久化字母树。

时间复杂度:\(O(60 m \log m + 60 n p\log m)\)(排序二分)

\(O(60m + 60^2np)\)(字母树)

平方运算

这个应该是最难的一题了吧(对我而言??)。

由于\(p\)是给出的,打个表就能发现一些奇怪的性质。这里我用一副图(\(p=233\))展示:图片像素太大,不妨下载下来放大看。

可以发现,整个图是若干连通块,对于一个连通块来说,是一个环加上周围的若干棵树。由于我没写过,听被人说所有环的长度的最小公倍数在\(60\)左右,每个点到环的距离在\(20\)左右。

假设一开始所有的数都在环上,我们可以维护一个线段树,每个结点记下该区间被修改\(k\)次后,该区间所有数的和,其中\(k\)取决于所有环的长度的最小公倍数。这样,时间复杂度为:\(O(60n\log n)\),这里\(k\)当\(60\)算。

现在由于有些数不在环上,我们暴力改并维护线段树就好,因为对于一个数而言,暴力改的次数在\(20\)左右。

解密运算

这题的代码短得吓人!THUSC居然有这样的题。

假设所有的数不同,那么就是水题一道,因为我们能轻易地算出第一列,同时由知道最后一列,那么我们就知道了每个数字后一个是什么数字。接着,从\(0\)开始就能推导出答案。

但是,如果有相同的,举个例子:

0 * * 1
1 * * 0
1 * * 2
2 * * 1

*表示尚未知的数字。

我们并不知道跟在第二行的\(0\)后面的\(1\)究竟是第一行最后一个\(1\),还是第四行最后一个。

我们可以这么想:

对于下面的情况,最后一列究竟是怎样的。

1(1) ...... 1(2) ...
1(2) ... 1(1) ......

括号里边的是唯一的标识。

我们可以把第一列移到最后一列,得到的新的行,并且这样的行一定存在。这样我们就发现了:对于同一个数字,相对的位置还是不变的。对于最初的例子来说,第二行的\(0\)后面的\(1\)就是第一行最后一个\(1\)。

...... 1(2) ... 1(1)
... 1(1) ...... 1(2)

这样,相同的数字其实“不相同”,我们可以加上唯一的标识,那就跟所有数字不相同的做法一样了。

到此,我们就搞定的THUSC的题目了。你觉得它有NOI的难度吗?

THUSC2015的更多相关文章

  1. BZOJ4105 THUSC2015平方运算(线段树)

    注意到模数被给出且非常小,做法肯定要依赖于一些与此相关的性质.找题解打表可以发现循环节长度的lcm不超过60. 考虑怎么用线段树维护循环.对线段树上每个点维护这段区间的循环节.在循环中的位置,如果未进 ...

  2. 【洛谷5794】[THUSC2015] 解密运算(模拟)

    点此看题面 大致题意: 对于一个字符串,我们在其末尾添加一个'.',将字符串视作一个环,则可以从\(n+1\)个位置断开得到\(n+1\)个新串.现将这\(n+1\)个新串按字典序排序('.'的字典序 ...

  3. 蒟蒻的PKUWC2019划水记(更新ing)

    前言 (结束再补) \(Dec\ 20th\) 正式出发 今天,是正式出发的日子. 虽说是星期五,可并没有去学校晨跑.难得睡到了\(7\)点,起来匆匆吃完了早饭(一个手抓饼),就出发去火车站了. 到了 ...

随机推荐

  1. protel99_拼板详细图解

    首先打开PCB文档.如图所示,在PCB左下角放置一個坐標為X=0,Y=0的焊盤. 从下图看,为了方便电路板生产厂家的加工和焊接工厂的加工,拼版的方向是向上Y轴方向拼版. 接着为了在拼版过程中好对齐板边 ...

  2. 使用Protel99 SE 拼板的详细图解(新加队列粘贴方法)

    很多网友跟我沟通,提到我上次博文中的protel99se中做拼板图解过于简略,应大家的有求,重新修改了操作图示. 首先打开PCB文档.如图所示:电路板的原点并没有在边上,为了操作方便和规范,先把有点设 ...

  3. perl5 第十二章 Perl5中的引用/指针

    第十二章 Perl5中的引用/指针 by flamephoenix 一.引用简介二.使用引用三.使用反斜线(\)操作符四.引用和数组五.多维数组六.子程序的引用  子程序模板七.数组与子程序八.文件句 ...

  4. Python生成随机数的方法

    这篇文章主要介绍了Python生成随机数的方法,有需要的朋友可以参考一下 如果你对在Python生成随机数与random模块中最常用的几个函数的关系与不懂之处,下面的文章就是对Python生成随机数与 ...

  5. hql中不能写count(1)能够写count(a.id)

    hql中不能写count(1)能够写count(a.id)里面写详细的属性 String hql="select new com.haiyisoft.vo.entity.cc.repo.Bu ...

  6. [译]SSRS 报表版本控制

    问题 如今商务智能应用广泛,对我们的商业愈加重要. 对新报表和的各种需求不断攀升. 自 SQL Server 2008 R2的 Reporting Services (SSRS) 开始,微软视图为减轻 ...

  7. Servlet学习的两个案例之网站访问次数的统计

    一.统计次数的Servlet源码 package com.shanrengo; import java.io.IOException; import javax.servlet.ServletCont ...

  8. Python 第一章 基础知识

    如果熟其他计算机语言,可能会习惯于每行以分号结束.Python则不同,一行就是一行,不管多少. 如果喜欢的话,可以加上分号,但是不会有任何作用(除非同一行还有更多的代码),而且这也不是同行的做法. & ...

  9. jxl读写excel, poi读写excel,word, 读取Excel数据到MySQL

    这篇blog是介绍: 1. java中的poi技术读取Excel数据,然后保存到MySQL数据中. 2. jxl读写excel 你也可以在 : java的poi技术读取和导入Excel了解到写入Exc ...

  10. BZOJ 1631: [Usaco2007 Feb]Cow Party

    题目 1631: [Usaco2007 Feb]Cow Party Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 491  Solved: 362[Sub ...