NOIP模拟赛第7场题解:

题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13

题号为2221-2224.

1.car

边界要当做建筑物。

只需要判断是否存在一个'.',至少三面都是建筑。那么这个点就是所谓的“死胡同”.

2.gcd

利用整数唯一分解定理,求出A,B的所有质因数和该质因数出现的次数。

对A,B的公共质因数取其出现次数的最小值,再将该质因数的最小值次幂累乘起来即可。

3.pair

这是一道非常有质量的题,很考思维。

暴搜的时间复杂度是O(N^2).只能处理n较小的数据。30分应该没有问题。

一般会想到容斥原理。

要统计num和之前的多少数形成一个pair,可以这样计算:与num有一个共同数字的数之和-与num有两个共同数字的数之和+与num有三个共同数字的数之和-……

如何计算与num有k个共同数字之和呢?可以这样做:

利用一个数组bit[2^10],如果当前数包含了数字i(出现多次算一次),则bit[1<<i]++;如果同时出现了i,j,则bit[1<<i]++,bit[1<<j]++,bit[(1<<j)|(1<<i)]++,如果包含i,j,k等多个数字,依次类推。

这样,要计算与num有一个共同数字的数的个数:sum(bit[1<<i])(0<=i<=9 &&num包含数字i)

这种方法很麻烦,而且时间复杂度为O(N*2^10).程序肯定会超时。

注意到bit[2^10]。为什么我们可以用这么小的一个数组来记录所有数“包含哪些数字”的信息?

思考后你会发现,其实对于一个数num,我们只关心它包含哪些数字,至于这些数字出现的顺序,出现的次数,都可以不用考虑。

所以我们把一个数num,转换为一个小于1024的数k。转换规则很简单,如果num包含数字i,则k中右数第i位设为1,否则第i位为0.

这样所有的数既可以映射到1个1024的区间,这样,相当于缩小了n的范围。现在可以用暴搜了解决了。

结果由两部分组成:

第一部分:设cnt[i]表示转换后得到的数i出现的次数。i和其他数形成的pair,即为cnt[i]*cnt[j].(j表示其他数,且i&j!=0)。最后将这些乘积累加,再除以2.(因为每个pair都计算了两次。)

第二部分:

i代表的是相同的一类数num,这些数对应同一个i,它们是两两成pair的,一共可以形成C(cnt[i],2)个pair。(组合计数,从cnt[i]个元素中取出两个,所以为C(cnt[i],2))。所有的i都可以得到一个C(cnt[i],2),这部分全部累加起来。

两部分的和即为答案。

第四题:如果26层循环相互之间没有关系,则是一个连乘即可解决的问题。

现在有些循环变量的边界是外层循环变量,我们称这两层循环有对应关系。

我们把每个循环变量看做一个节点,有对应关系的节点连一条边。具体说:题目说了,任意一个变量的两个边界中,至少有一个为常量,

也就是说之多只有一个边界为变量。如果v2的一个边界为v1,则v1向v2连一条边。这样会得到一个森林,即多棵树。

树中的节点即一个循环变量,所有循环变量给res带来的贡献即该树的结果。

树与树之间是互相独立的。最后的res值等于每棵树代表的结果的乘积。

如何计算一棵树的结果。

设f[root]为以root为根的子树的结果,g(node,number)表示节点node表示的变量取值为number时,其子树的结果。则有下列式子

注意下式中,g(node,number)只给出了一种情形,node所表示的变量的上界为常数;还有另一种情形,即node所表示的变量的下界为常数,g(node,number)的表达式要稍作修改,但其实本质都差不多的。下面的式子中,类似于pi的符号表示取乘积。

这个时间复杂度是O(nm2)的,只能过70%的数据。

注意到,g(node,number)的计算是可以递推得到的,即

这样,时间复杂度为O(nm)了。

NOIP第7场模拟赛题解的更多相关文章

  1. 2018.12.30【NOIP提高组】模拟赛C组总结

    2018.12.30[NOIP提高组]模拟赛C组总结 今天成功回归开始做比赛 感觉十分良(zhōng)好(chà). 统计数字(count.pas/c/cpp) 字符串的展开(expand.pas/c ...

  2. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  3. 10.6-10.7 牛客网NOIP模拟赛题解

    留个坑... upd:估计这个坑补不了了 如果还补不了就删了吧

  4. 『7.5 NOIP模拟赛题解』

    T1 Gift Description ​ 人生赢家老王在网上认识了一个妹纸,然后妹纸的生日到了,为了表示自己的心 意,他决定送她礼物.可是她喜爱的东西特别多,然而他的钱数有限,因此他想 知道当他花一 ...

  5. 『7.3 NOIP模拟赛题解』

    T1 gift Description ​ 夏川的生日就要到了.作为夏川形式上的男朋友,季堂打算给夏川买一些生日礼物. ​ 商店里一共有种礼物.夏川每得到一种礼物,就会获得相应喜悦值Wi(每种礼物的喜 ...

  6. NOIp 2015真题模拟赛 By cellur925

    果然我还是最菜的==不接受反驳== Day1 T1:神奇的幻方 思路:直接模拟即可,由于当前放法只与上一放法有关系,用两个变量记录一下即可.10分钟内切掉== 预计得分:100分 实际得分:100分 ...

  7. 20220303模拟赛题解and总结

    目录 总结 A.不幸的7 B.选举 C. 差的绝对值之和 D. 路径通过 总结 初一第一 一般,最后一题没打好 不难发现,教练出水了,可能是信心赛 A.不幸的7 暴力,没有逻辑可言 #include& ...

  8. 2017.08.08【NOIP提高组】模拟赛B组

    Summary 今天的题目也不算很难,唯一一道没做出来的题目是以前做过的,太不应该了. Problem T1 油滴扩展 题目大意 给你一堆点,你准备要在这么多的点当中滴油.你可以自己安排顺序,每次滴油 ...

  9. 2017.08.06【NOIP提高组】模拟赛B组

    Summary 今天的比赛60+100+100=260分,没有想到第一题正解是搜索,我与AK差一段距离,这段距离,叫倒着搜.总的来说不是很难. Problem T1 天平 题目大意 给你N个排序好的砝 ...

随机推荐

  1. view的加载

    这是一个listpopwindow的布局,如果listview在relativeLayout之后写的那么listview就会把relativeLayout给覆盖掉,这证明布局的加载是按照布局文件写的先 ...

  2. int integer string间的转换

    1.int-->Integer new Integer(i); 2.Integer-->int Integer i = new Integer(1); int k = i.intValue ...

  3. 转 用 AXIOM 促进 XML 处理

    转自:http://www.ibm.com/developerworks/cn/xml/x-axiom/ AXIOM 还不是另一种对象模型.它有着明确的设计目标:大幅提升 Apache 下一代 SOA ...

  4. C中scanf/gets/fgets的区别

    功能:同样是获取字符串. 区别: scanf 遇到空格/回车/Tab键认为输入结束, 但是空格/回车/Tab键仍会留在输入的缓冲区中.常见的是使用getchar(),处理scanf的后事:如果想要清除 ...

  5. java的nio之:浅析I/O模型

    也许很多朋友在学习NIO的时候都会感觉有点吃力,对里面的很多概念都感觉不是那么明朗.在 进入Java NIO编程之前,我们今天先来讨论一些比较基础的知识:I/O模型.下面本文先从同步和异步的概念 说起 ...

  6. 【转】BLE_CC2540_初学者入门指导

    原文网址:http://www.deyisupport.com/question_answer/wireless_connectivity/bluetooth/f/103/t/61462.aspx 看 ...

  7. 3D知识补充

    Light Mapping = Dark Mapping (光照映射.黑暗映射) 本质上也是多贴一张图,他是做相乘操作.第2张纹理通常中间亮,外面暗.如果是简单的 Modulate,那么实际上所有像素 ...

  8. php 错误 Strict Standards: PHP Strict Standards: Declaration of .... should be compatible with that of 解决办法

    错误原因:这是由于 php 5.3版本后.要求继承类必须在父类之后定义.否则就会出现Strict Standards: PHP Strict Standards: Declaration of ... ...

  9. java 中的断言assert的使用

    一.assertion的意义和用法 J2SE 1.4在语言上提供了一个新特性,就是assertion功能,它是该版本在Java语言方面最大的革新. 从理论上来说,通过 assertion方式可以证明程 ...

  10. 在EntityFramework中使用 nock的方法。

    以下内容为转载: A:https://dotblogs.com.tw/asdtey/2009/09/27/10793 B:http://www.gitshah.com/2014/08/how-to-a ...