A、最长树链(loj6159)

分析:

对于每个质因数,取出所有是它倍数的点组成一个树,然后找最长路径

每个数操作次数是其质因数的个数

所以总的复杂度不超过O(nlogA)

B、二分图染色(loj6160)

分析:

先转换模型——一个n*n的棋盘上,对于每个格子,可以下黑子,可以下白子,可以不下子,要求同一行同一列颜色相同的棋子最多只有一个

考虑黑白两种颜色不太好考虑,我们去考虑单个颜色

设An表示n*n的棋盘上,放若干个棋子,同一行同一列最多只有一个棋子的方案数

那么有An=ΣC(n,i)*P(n,i) (枚举哪些行放棋子,然后这些行棋子的列做排列)

再考虑两种颜色,我们把两个棋盘拼起来,发现矛盾点就是不能有格子既有黑子又有白子

那么想到容斥:An*An- 至少有一个格子重叠 + 至少有两个格子重叠 - 至少有三个格子重叠……

对于重叠怎么计算呢?一个格子如果重叠了,那么这个格子所在行列都不能放其它棋子了,所以这行这列相当于删去了

所以至少有i个格子重叠可以表示成:C(n,i)*P(n,i)*A(n-i)*A(n-i)

看一下时间复杂度,题目要求在线性时间内完成,求An就成为了一个问题

其实An可以递推求得:An=2nA(n-1)-(n-1)*(n-1)*A(n-2) (留个坑,暂时不太弄懂啥意思?)

C、倒水(loj6161)

分析:

容易发现当大水缸里水的容量介于水杯水之间的时候,一定是无解的

只有在两边才有解

如果在左边,那么答案一定是最小的那个;如果在右边,那么可以二分

D、身体训练(loj6162)

分析:

期望式子推一推就出来了

E、合并回文子串(loj6163)

分析:

考虑dp

dp[i][j][k][l]表示a[i..j]和b[k..l]结合能否成为一个回文串

那么显然一共有4种转移

注意下初值就行了

F、数列互质(loj6164)

分析:

第一想法肯定就是莫队,也容易想到记录当前区间每个数出现次数以及“出现次数”的出现次数

那么时间复杂度就是O(nsqrt(n)+m*MAX*logA)

其中MAX是出现次数的最大值,logA是求gcd的时间

如果MAX是根号级别的就好了,但明显此题中MAX会很大,那么怎么办呢?

我们可以先做一个这样的处理:挑出所有在数组中出现次数>=sqrt(n)的数字,把这些数字用一个桶一刷,求个前缀和,然后遍历所有询问,算这个数字对每个询问的贡献

因为出现次数>=sqrt(n)的数字个数肯定不会超过sqrt(n)个,所以这个的时间复杂度就是O(sqrt(n)*m)

然后对于那些出现次数<sqrt(n)的数字进行莫队,那么MAX就是sqrt(n)了

所以整个复杂度就是O(nsqrt(n)+msqrt(n)+m*sqrt(n)*logA)

2017CodeM初赛A场的更多相关文章

  1. 2017CodeM初赛B场

    A.合并字符串价值(loj6174) 分析: 普通暴力:枚举两个分界线,那么ans=Σmin(Al(c)+Bl(c),Ar(c)+Br(c)),这样是O(n^2),会TLE 考虑枚举a的分界线,b的答 ...

  2. 2018 计算之道初赛第二场 阿里巴巴的手机代理商(困难)(反向可持久化Trie)

    阿里巴巴的手机代理商(困难) 阿里巴巴的手机代理商正在研究 infra 输入法的新功能.他们需要分析单词频率以改进用户输入法的体验.于是需要你在系统内核里面写一个 API. API 有如下功能: 添加 ...

  3. # 「银联初赛第一场」自学图论的码队弟弟(dfs找环+巧解n个二元一次方程)

    「银联初赛第一场」自学图论的码队弟弟(dfs找环+巧解n个二元一次方程) 题链 题意:n条边n个节点的连通图,边权为两个节点的权值之和,没有「自环」或「重边」,给出的图中有且只有一个包括奇数个结点的环 ...

  4. 动态规划-hdoj-4832-百度之星2014初赛第二场

    Chess Problem Description 小度和小良近期又迷上了下棋.棋盘一共同拥有N行M列,我们能够把左上角的格子定为(1,1),右下角的格子定为(N,M).在他们的规则中,"王 ...

  5. 计蒜之道 初赛第一场B 阿里天池的新任务(简单)

    阿里“天池”竞赛平台近日推出了一个新的挑战任务:对于给定的一串 DNA 碱基序列 tt,判断它在另一个根据规则生成的 DNA 碱基序列 ss 中出现了多少次. 首先,定义一个序列 ww: \displ ...

  6. 2019 计蒜之道 初赛 第二场 B. 百度AI小课堂-上升子序列(简单) ( 实现)

    题目背景 ​91029102 年 99 月 22 日,百度在 X 市 XX 中学举办的第一场 AI 知识小课堂大获好评!同学们对矩阵的掌握非常棒. 今天的 AI 知识小课堂的第二场开讲啦.本场 AI ...

  7. 2019 计蒜之道 初赛 第二场 A 百度AI小课堂-矩阵问题 ( 等差数列求和公式)

    题目背景 ​91029102 年 99 月 11 日,百度在 X 市 XX 中学举办了一场 AI 知识小课堂,本场 AI 知识小课堂老师教授了一些矩阵的相关知识,因为矩阵在 AI 人工智能中也有相当的 ...

  8. 2014百度之星初赛第二场hdu 4831 Scenic Popularity

    Scenic Popularity Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  9. 【AStar】初赛第一场

    1. All X1.1 基本思路k和c的范围都不大,因此可以考虑迭代找循环节,然后求余数,判定是否相等.这题还是挺简单的.1.2 代码 /* 5690 */ #include <iostream ...

随机推荐

  1. 我的关于phoneGap的安装及测试。

    一.PhoneGap简介 PhoneGap是一个用基于HTML,CSS和JavaScript的,创建移动跨平台移动应用程序的快速开发平台.它使开发者能够利用 iPhone,Android,Palm,S ...

  2. 记一次mysql优化操作

    这次操作,起因是需要获取用户来源及用户性别,而用户的性别信息在第三方授权的中有,存为JSON格式, 不想用php去解析获取,所以试试mysql操作 如果你有更好的解决方案,请留言告诉我! 情景简化 表 ...

  3. leetcode_935. Knight Dialer_动态规划_矩阵快速幂

    https://leetcode.com/problems/knight-dialer/ 在如下图的拨号键盘上,初始在键盘中任意位置,按照国际象棋中骑士(中国象棋中马)的走法走N-1步,能拨出多少种不 ...

  4. Android(java)学习笔记177: 服务(service)之音乐播放器

    1.我们播放音乐,希望在后台长期运行,不希望因为内存不足等等原因,从而导致被gc回收,音乐播放终止,所以我们这里使用服务Service创建一个音乐播放器. 2.创建一个音乐播放器项目(使用服务) (1 ...

  5. 循环实现数组filter方法

    // 循环实现数组 filter 方法 const selfFilter = function (fn, context){ // 如果调用的地方使用箭头函数,这里的this岂不是不对了,那该怎么解决 ...

  6. 两个乒乓球队进行比赛,各出三人。 甲队为a,b,c三人,乙队为x,y,z三人。 已抽签决定比赛名单。 有人向队员打听比赛的名单。 a说他不和x比,c说他不和x,z比, 请编程序找出三队赛手的名单。

    题目:两个乒乓球队进行比赛,各出三人. 甲队为a,b,c三人,乙队为x,y,z三人. 已抽签决定比赛名单. 有人向队员打听比赛的名单. a说他不和x比,c说他不和x,z比, 请编程序找出三队赛手的名单 ...

  7. 【收藏】史上最全的浏览器 CSS & JS Hack 手册

    浏览器渲染页面的方式各不相同,甚至同一浏览器的不同版本(“杰出代表”是 IE)也有差异.因此,浏览器兼容成为前端开发人员的必备技能.如果有一份浏览器 Hack 手册,那查询起来就方便多了.这篇文章就向 ...

  8. 优化UITableView

    在iOS应用中,UITableView应该是使用率最高的视图之一了.iPod.时钟.日历.备忘录.Mail.天气.照片.电话.短信.Safari.App Store.iTunes.Game Cente ...

  9. css module

    来源:CSS Modules 用法教程 后面项目地址:https://github.com/947133297/lwj-webpack-demo 关键是打开这一行,表示开启loader的css mod ...

  10. ubuntu修改apt-get源为国内镜像源

    1.原文件备份   sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak   2.编辑源列表文件   sudo vim /etc/apt/so ...