2020.02.01【NOIP提高组】模拟B 组总结反思——数列(sequence) 树 【2012东莞市选】时间流逝 挖掘机技术哪家强
T1 数列(sequence)
比赛时
我自以为是地打了简简单单一个判断~~~
之后
Waiting……
T2 2753. 树(tree)
比赛时
这题我居然比赛时也想了很久,可能是因为我太懒,我很早意识到lca的思想可以做,但是我还是想有什么办法更简单,如一个玄学的DFS、诡异的树形DP(显然时间会炸),浪费了我很多时间,最终我没有想到。我就来讲讲lca的做法吧,由于路径中节点的深度必须是升序的,可以知道一条路径,它的起点必定是终点的祖先,符合lca。\(n \leq 100000\),那么枚举终点,设两个数组:\(fa[i][j]\)表示编号为i的节点向上跳\(2^j\)次的节点,\(a[i][j]\)表示编号为i的节点向上跳\(2^j\)次途中遇到的节点价值总和。原汁原味的lca判断的是深度,这里改一改就可以了,设变量\(sum=b[x]\)(x表示终点),每次向上跳时判断\(sum+a[x][j] < s\),跳的时候加一下就可以了。时间复杂度为\(O(20n)\),显然这个20非常小,可以不写。
之后
有同学用了暴力居然都过了,这卡常居然能过,不公平呀,数据也太水了吧。
总结
不能太懒,想到一个AC的方法,如果在短时间内没有想到更简单的方法,则打。
T3 2754. 【2012东莞市选】时间流逝(flow)
比赛时
一看到概率,我就几乎想放弃,我不知道因为概率的存在期望天数怎么算(但其实很简单,我太蒟了~~)
之后
没有之后~~~没几个人做对,听不懂。
T4 3858. 挖掘机技术哪家强 shoberu
题目描述
给出n,求出n的每个因数x的难挖指数的和,难挖指数是所有与x互质的数y的和(包括1,\(1 \leq y \leq x\))
比赛时
一看到这是偏数学题,就泄了气。n太大了,1000000000,而且多组数据,1000组。我就想,可以枚举x,时间复杂度约为\(O(3000)\),那么处理x的难挖指数的时间复杂度最多用\(O(10)\),没有想到高效求的方法。想来想去,并没有想到什么规律。放弃~
之后
正解:欧拉函数,可惜我还没学。欧拉函数可以求出对于一个x,y有多少个,和本题题意极其相似。我们发现:对于一个x,y总是成对出现(证明是显然的,若 p 与 x 互质,那么p 与 x-p 也互质。我们把 p 与 x-p 结成一对),且一对和为x;如\(x=14\),y有\(1,3,5,9,11,13\),每组和都\(=x\)。于是我们可以用欧拉函数求出x的y有多少个,就可以求出难挖指数是多少,一个x时间复杂度为\(O(\log n)\),常数级别,那么整个的时间复杂度为\(O(t \sqrt{n})\),完全可以过,注意有特殊情况:x=1,x=2。
#include<cstdio>
int t,n;
long long ans;
inline int euler(int x){
int ans=x;
for(int i=2;i*i<=x;i++){
if(x%i==0) ans-=ans/i;
while(x%i==0) x/=i;
}
if(x>1) ans-=ans/x;
return ans;
}
inline long long func(int x){
if(x==1||x==2){
return 1;
}else{
int g=euler(x);
return (long long)g*x/2;
}
}
int main(){
scanf("%d",&t);
for(int l=0;l<t;l++){
scanf("%d",&n);
ans=0;
for(int i=1;i*i<=n;i++)
if(n%i==0){
ans+=func(i);
if(n/i!=i) ans+=func(n/i);
}
printf("%lld\n",ans);
}
return 0;
}
2020.02.01【NOIP提高组】模拟B 组总结反思——数列(sequence) 树 【2012东莞市选】时间流逝 挖掘机技术哪家强的更多相关文章
- JZOJ 5185. 【NOIP2017提高组模拟6.30】tty's sequence
5185. [NOIP2017提高组模拟6.30]tty's sequence (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB ...
- 【纪中集训】2019.08.02【NOIP提高组】模拟 A 组TJ
\(\newcommand{\RNum}[1]{\uppercase\expandafter{\romannumeral #1\relax}}\) T1 一道可以暴力撵标算的题-- Descripti ...
- 【洛谷】NOIP提高组模拟赛Day2【动态开节点/树状数组】【双头链表模拟】
U41571 Agent2 题目背景 炎炎夏日还没有过去,Agent们没有一个想出去外面搞事情的.每当ENLIGHTENED总部组织活动时,人人都说有空,结果到了活动日,却一个接着一个咕咕咕了.只有不 ...
- JZOJ5857 【NOIP提高组模拟A组2018.9.8】没有上司的舞会
题目 Description "那么真的有果尔德施坦因这样一个人?"他问道. "是啊,有这样一个人,他还活着.至于在哪里,我就不知道了." "那么那个 ...
- [jzoj 5770]【2018提高组模拟A组8.6】可爱精灵宝贝 (区间dp)
传送门 Description Branimirko是一个对可爱精灵宝贝十分痴迷的玩家.最近,他闲得没事组织了一场捉精灵的游戏.游戏在一条街道上举行,街道上一侧有一排房子,从左到右房子标号由1到n. ...
- [JZOJ5185] 【NOIP2017提高组模拟6.30】tty's sequence
Description
- 2020牛客NOIP赛前集训营-普及组(第二场)A-面试
面 试 面试 面试 题目描述 牛牛内推了好多人去牛客网参加面试,面试总共分四轮,每轮的面试官都会对面试者的发挥进行评分.评分有 A B C D 四种.如果面试者在四轮中有一次发挥被评为 D,或者两次发 ...
- 2020牛客NOIP赛前集训营-普及组(第二场) 题解
目录 T1 面试 描述 题目描述 输入描述: 输出描述: 题解 代码 T2 纸牌游戏 描述 题目描述 输入描述: 输出描述: 题解 代码 T3 涨薪 描述 题目描述 输入描述: 输出描述: 题解 代码 ...
- NOIP第二次模拟赛 stage1【划分数列(seq.pas/c/cpp)
7划分数列(seq.pas/c/cpp) [题目描述] 给你一个有n个元素的数列,要求把它划分成k段,使每段元素和的最大值最小 [输入格式] 第一行两个正整数n,k 第二行为此数列ai [输出格式] ...
随机推荐
- Codeforces 1156E Special Segments of Permutation(启发式合并)
题意: 给一个n的排列,求满足a[l]+a[r]=max(l,r)的(l,r)对数,max(l,r)指的是l到r之间的最大a[p] n<=2e5 思路: 先用单调栈处理出每个点能扩展的l[i], ...
- 如何在windows10家庭版上搭建docker
如何在windows10家庭版上搭建docker 建议先跳到最后一条,看完之后再决定是否安装. 0X00搭建原因 首先搭docker的想法是我在复现漏洞时候,发现大佬们的复现环境都是基于docker的 ...
- Wannafly挑战赛5 A珂朵莉与宇宙 前缀和+枚举平方数
Wannafly挑战赛5 A珂朵莉与宇宙 前缀和+枚举平方数 题目描述 给你一个长为n的序列a,有n*(n+1)/2个子区间,问这些子区间里面和为完全平方数的子区间个数 输入描述: 第一行一个数n 第 ...
- [redis读书笔记] 第一部分 数据结构与对象 链表
二 链表 1.链表节点使用ListNode结构,是一个双向的链表,同时,还实现了一个控制所有ListNode的结构list: typedef struct listNode { // 前置节点 str ...
- SpringBoot嵌入式Servlet配置原理
SpringBoot嵌入式Servlet配置原理 SpringBoot修改服务器配置 配置文件方式方式修改,实际修改的是ServerProperties文件中的值 server.servlet.con ...
- Vue路由(vue-router)
一.介绍 1.vue-router安装 官方文档:https://router.vuejs.org/zh/installation.html下载地址:https://unpkg.com/vue-rou ...
- Cacti 安装插件
Cacti本身可以以图形化界面显示出流量状态,cacti也可以安装插件,通过插件,cacti的功能被进一步强大:可以监控服务器状态:发送邮件通知:短信通知等. 0.88之 ...
- Day2前端学习之路——HTML基本知识
课程目标: 通过制作自己的简历,更加清楚地了解HTML是什么,HTML5是什么.学习基本的HTML标签,理解HTML语义化概念 任务一:回答问题 1.HTML是什么,HTML5是什么? HTML是一种 ...
- QT学习之路-QT服务器-mysql数据库相关问题集锦(1)
时间:2017-04-07 异常信息: Error - RtlWerpReportException failed with status code :-1073741823. Will try to ...
- export和export default的区别
export和export default的区别一.export的使用1.直接输出export let words = ‘hello world!!!’export function output() ...