CH round #55 Streaming #6
T^T Saffah大神照样刷我这样诚心诚意想做一套NOIP模拟题的蒟蒻.
第一题 九九归一
好diao的名字...
题意就是给定一队$n,q$,求在模$n$意义下一个数$x$自乘的循环节长度.
当$x=0$时候输出$0$是吧...
.................................................实在是太弱了....................................................
连个思路都没有.....
再看一遍题目
萌蛋在练习模n意义下的乘法时发现,总有一些数,在自乘若干次以后,会变成1。例如n=7,那么5×5 mod 7=4,4×5 mod 7=6,6×5 mod 7=2,2×5 mod 7=3,3×5 mod 7=1。如果继续乘下去,就会陷入循环当中。萌蛋还发现,这个循环的长度经常会是φ(n),即小于n且与n互质的正整数的个数。例如,φ(7)=6,而上述循环的长度也是6,因为5,4,6,2,3,1共有6个数。再如n=6,那么5×5 mod 6=1。这个循环的长度很短,只有2,而恰好φ(6)=2。然而,对于某些情况,虽然循环的长度可以是φ(n),但存在比φ(n)更小的长度:例如n=7,而2×2 mod 7=4,4×2 mod 7=1,循环的长度只有3。当然,6也可以是一个循环的长度。假设已知了n,我们称数a神奇的,当且仅当关于数a的循环长度可以是φ(n),而且不存在比φ(n)更小长度的循环。例如对于n=7,5是神奇的,而2不是神奇的。现在给出n和q次询问,每次询问给出a,问a是否是神奇的。
这个循环长度为φ(n)的条件...既然$x^{φ\left( n\right)}\equiv 1 \pmod{n}$,看起来很像欧拉定理...大声告诉我是不是!!!
光知道这个有个P用...真是书到用时方恨少...
还是等Saffah大神的官方题解吧
第二题
似乎有种会做了的感觉...
对于每个节点,将它的每子树节点的w值的和一乘完事...
好吧没时间了.
- #include <cstdio>
- #define MOD 1000000007
- long long fat[200000],w[200000],f[200000],sub[200000],totw[200000],n,p,i,sum;
- long long q[200000],qh,qt;
- int main(){
- scanf("%lld %lld",&n,w+1);
- for(i=2;i<=n;++i){
- scanf("%lld %lld",fat+i,w+i);
- ++sub[fat[i]];
- }
- for(i=1;i<=n;++i){
- f[i]=0;
- if(!sub[i]){
- q[qt++]=i;
- totw[i]=0;
- f[i]=0;
- }
- }
- while(qh!=qt){
- i=q[qh++];
- f[i]+=(((w[i]*w[i])%MOD)*(w[i]+totw[i]*2))%MOD;
- totw[i]+=w[i];
- sum=(sum+f[i])%MOD;
- f[fat[i]]+=totw[i]*totw[fat[i]]*w[fat[i]]*2;
- totw[fat[i]]+=totw[i];
- f[fat[i]]%=MOD;
- --sub[fat[i]];
- if(!sub[fat[i]]) q[qt++]=fat[i];
- }
- printf("%lld\n", sum);
- return 0;
- }
-----UPDATE: 似乎没有Mod到位...改一下-----
- #include <cstdio>
- #include <cstring>
- #define MOD 1000000007
- long long fat[200000],w[200000],f[200000],sub[200000],totw[200000],n,p,i,sum;
- long long q[200000],qh,qt;
- int main(int argc,char const *argv[]){
- scanf("%lld %lld",&n,w+1);
- for(i=2;i<=n;++i){
- scanf("%lld %lld",fat+i,w+i);
- ++sub[fat[i]];
- }
- for(i=1;i<=n;++i){
- f[i]=0;
- if(!sub[i]){
- q[qt++]=i;
- totw[i]=0;
- f[i]=0;
- }
- }
- while(qh!=qt){
- i=q[qh++];
- f[i]+=(((w[i]*w[i])%MOD)*((w[i]+totw[i]*2)%MOD))%MOD;
- totw[i]+=w[i];
- totw[i]%=MOD;
- sum=(sum+f[i])%MOD;
- f[fat[i]]+=(totw[i]*totw[fat[i]])%MOD*w[fat[i]]*2;
- totw[fat[i]]+=totw[i];
- totw[fat[i]]%=MOD;
- f[fat[i]]%=MOD;
- --sub[fat[i]];
- if(!sub[fat[i]]) q[qt++]=fat[i];
- }
- printf("%lld\n", sum);
- return 0;
- }
这个程序是AC的.
CH round #55 Streaming #6的更多相关文章
- CH Round #55 - Streaming #6 (NOIP模拟赛day2)解题报告
T1九九归一 描述 萌蛋在练习模n意义下的乘法时发现,总有一些数,在自乘若干次以后,会变成1.例如n=7,那么5×5 mod 7=4,4×5 mod 7=6,6×5 mod 7=2,2×5 mod 7 ...
- CH Round #55 - Streaming #6 (NOIP模拟赛day2)
A.九九归一 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2355%20-%20Streaming%20%236%20(NOIP模拟赛day2)/九九归一 题 ...
- CH Round #55 - Streaming #6 (NOIP模拟赛day2)(被虐哭)
http://ch.ezoj.tk/contest/CH%20Round%20%2355%20-%20Streaming%20%236%20%28NOIP%E6%A8%A1%E6%8B%9F%E8%B ...
- CH Round #54 - Streaming #5 (NOIP模拟赛Day1)解题报告
最近参加了很多CH上的比赛呢~Rating--了..题目各种跪烂.各种膜拜大神OTZZZ T1珠 描述 萌蛋有n颗珠子,每一颗珠子都写有一个数字.萌蛋把它们用线串成了环.我们称一个数字串是有趣的,当且 ...
- CH Round #49 - Streaming #4 (NOIP模拟赛Day2)
A.二叉树的的根 题目:http://www.contesthunter.org/contest/CH%20Round%20%2349%20-%20Streaming%20%234%20(NOIP 模 ...
- CH Round #48 - Streaming #3 (NOIP模拟赛Day1)
A.数三角形 题目:http://www.contesthunter.org/contest/CH%20Round%20%2348%20-%20Streaming%20%233%20(NOIP模拟赛D ...
- CH Round #54 - Streaming #5 (NOIP模拟赛Day1)
A.珠 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2354%20-%20Streaming%20%235%20(NOIP模拟赛Day1)/珠 题解:sb题, ...
- CH Round #54 - Streaming #5 (NOIP模拟赛Day1)(被虐瞎)
http://ch.ezoj.tk/contest/CH%20Round%20%2354%20-%20Streaming%20%235%20%28NOIP%E6%A8%A1%E6%8B%9F%E8%B ...
- CH Round #52 还教室[线段树 方差]
还教室 CH Round #52 - Thinking Bear #1 (NOIP模拟赛) [引子]还记得 NOIP 2012 提高组 Day2 中的借教室吗?时光飞逝,光阴荏苒,两年过去了,曾经借教 ...
随机推荐
- __weak typeof(self) weakSelf = self
typeof(self) 是获取到self的类型,这样定义出的weakSelf就是和self一个类型的, 加上__weak是建立一个若引用,整句就是给self定义了一个若引用性质的替身;这个一般用在使 ...
- 【OpenCV入门教程之二】OPENCV3 开源之美 — 编译源代码、配置opencv_contrib
为什么要配置opencv_contrib? opencv3.0版本 功能更加模块块,一些功能模块不够完善,等足够完善在merge到主分支中,而我们图像识别中要用到的SIFT等算法被封装在xfeactu ...
- 配置个舒心的 Java 开发环境
Redmonk发布Java框架流行度调研结果:http://www.infoq.com/cn/news/2016/09/redmonk-java-frameworks 尝试:Intellij IDEA ...
- NumberFormat类的用法
NumberFormat.getInstance()方法返回NumberFormat的一个实例(实际上是NumberFormat具体的一个子类,例如DecimalFormat), 这适合根据本地设置格 ...
- maven初学(三) SNAPSHOT
使用场景: 通常一个大型软件是由多个模块组成的,不同的组使用相同应用的不同版本. 在开发阶段,可能经常需要修复bug和优化. 这种情况下就会导致其他组频繁更新代码和pom文件 SANPSHOT SNA ...
- Vijos p1892 树上的最大匹配 树形DP+计数 被卡常我有特殊技巧heheda
https://vijos.org/p/1892 此题需要手动开栈: <<; //256MB char *p=(char*)malloc(size)+size; __asm__(" ...
- 在VS2012中编译WinXP兼容的程序
VS2012默认是不兼容Windows XP的,编译链接出来的程序只能在Windows Vista及以上版本的操作系统上运行.可是有时需要在Windows XP上运行,又不得不用VS2012(例如用了 ...
- Yii2 实现修改密码功能
YII2对密码加密生成的结果是不同的,即用相同的初始密码在不同时间得到的加密结果不同,所以我们不能用常用的方法去验证密码是否正确(将密码加密后与数据库中的密码相比较).YII2有自己的加密以及密码验证 ...
- 12.Android之Tabhost组件学习
TabHost是整个Tab的容器,TabHost的实现有两种方式: 第一种继承TabActivity,从TabActivity中用getTabHost()方法获取TabHost.各个Tab中的内容在布 ...
- appium-车友会欢迎界面向右滑动4次点击‘立即体验’进入首屏
代码如下: driver.swipe(610, 2452, 658, 2452, 200) 只是示例滑动1页,可以使用循环,下一页比上一页x坐标大48