题面:https://www.cnblogs.com/Juve/articles/11648975.html

神炎皇:

打表找规律?和$\phi$有关?

答案就是$\sum\limits_{i=2}^{n}\phi(i)*\frac{n}{i*i}$

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define int long long
using namespace std;
int n,ans=;
int prime[],tot=,phi[];
bool vis[];
void get_phi(int N){
vis[]=phi[]=;
for(int i=;i<=N;i++){
if(!vis[i]) prime[++tot]=i,phi[i]=i-;
for(int j=;j<=tot&&i*prime[j]<=N;j++){
vis[i*prime[j]]=;
if(!(i%prime[j])){
phi[i*prime[j]]=phi[i]*prime[j];
break;
}
phi[i*prime[j]]=phi[i]*phi[prime[j]];
}
}
}
signed main(){
scanf("%lld",&n);
get_phi(sqrt(n)+);
for(int i=;i<=sqrt(n);++i)
ans+=phi[i]*(n/(i*i));
printf("%lld\n",ans);
return ;
}

降雷皇

基础不牢,地动山摇。。。赶紧补一发LIS

给定序列$a_i$,设f[i]表示以a[i]结尾的最长上升序列长度

则$f[i]=max(f[j]+1)(j<i\&\&a[j]<a[i])$

设g[i]表示以i为结尾的最长上升序列的个数

则有$g[i]=\sum\limits_{j=1}^{i-1}[a[j]<a[i]\&\&f[j]=f[i]-1]*g[j]$

这样就有了$O(n^2)$转移

然后用树状数组加速转移

树状数组下标为权值,顺序扫保证了j<i,树状数组查询a[i]-1保证了a[j]<a[i],然后树状数组即可

当然也可以线段树,原理是一样的

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=1e5+5;
const int mod=123456789;
int n,typ,a[MAXN],mx=0;
pair<int,int>c[MAXN*10],f[MAXN],ans;//changdu,geshu
int lowbit(int x){
return x&(-x);
}
int update(int pos,pair<int,int> val){
for(int i=pos;i<=mx;i+=lowbit(i)){
if(c[i].first<val.first) c[i]=val;
else if(c[i].first==val.first) (c[i].second+=val.second)%=mod;
}
}
pair<int,int> query(int pos){
pair<int,int>res;
res.first=0,res.second=1;
for(int i=pos;i>0;i-=lowbit(i)){
if(res.first<c[i].first) res=c[i];
else if(res.first==c[i].first) (res.second+=c[i].second)%=mod;
}
return res;
}
int main(){
scanf("%d%d",&n,&typ);
for(int i=1;i<=n;++i) scanf("%d",&a[i]),mx=max(mx,a[i]);
for(int i=1;i<=n;++i){
f[i]=query(a[i]-1);
++f[i].first;
update(a[i],f[i]);
if(ans.first<f[i].first) ans=f[i];
else if(ans.first==f[i].first) (ans.second+=f[i].second)%=mod;
}
if(typ==0) printf("%d\n",ans.first);
else printf("%d\n%d\n",ans.first,ans.second);
return 0;
}

幻魔皇:

产生贡献的只有白点,我们按两个白点lca的颜色分类

如果两个白点lca是白点,那么这个白点一定是两个白点中的一个

枚举两个白点的距离,不难发现只有深度在[1,n-i]的白点在它的子树中有距离为i的白点

设sum[i]表示前i层白点个数,w[i]表示第i层白点个数,因为每个白点的子树结构都相同,所以每个白点所在子树中第i层的白点个数都相等

所以贡献就是sum[n-i]*w[i],

如果两个白点的lca是黑点,枚举两个白点到黑点的距离i,j,只有深度为[1,n-max(i,j)]的黑点有贡献

设f[i]表示前i层的黑点个数,那么答案就是f[n-max(i,j)]*w[i]*w[j+1],其中i,j是有顺序的,i表示在黑点的白儿子的子树中的点,j表示在黑点的黑儿子的子树中的点

sum[],w[],f[]用fib递推

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define int long long
using namespace std;
const int MAXN=;
const int mod=;
int n,w[MAXN],sum[MAXN],f[MAXN],ans[MAXN<<];
signed main(){
scanf("%lld",&n);
w[]=w[]=w[]=;w[]=;
for(int i=;i<=n;++i) w[i]=(w[i-]+w[i-])%mod;
for(int i=;i<=n;++i) sum[i]=(sum[i-]+w[i])%mod;
f[]=,f[]=f[]=;
for(int i=;i<=n;++i) f[i]=(f[i-]+f[i-])%mod;
for(int i=;i<=n;++i) f[i]=(f[i-]+f[i])%mod;
for(int i=;i<n;++i){
(ans[i]+=(sum[n-i]*w[i+])%mod)%=mod;
for(int j=;j<n;++j)
(ans[i+j]+=f[n-max(i,j)]*w[i]%mod*w[j+]%mod)%=mod;
}
for(int i=;i<=*n;++i) printf("%lld ",ans[i]);
puts("");
return ;
}

csps模拟67神炎皇,降雷皇,幻魔皇题解的更多相关文章

  1. [CSP-S模拟测试]:神炎皇(数学)

    题目描述 神炎皇乌利亚很喜欢数对,他想找到神奇的数对. 对于一个整数对$(a,b)$,若满足$a+b\leqslant n$且$a+b$是$ab$的因子,则称为神奇的数对.请问这样的数对共有多少呢? ...

  2. NOIP模拟26「神炎皇·降雷皇·幻魔皇」

    T1:神炎皇   又是数学题,气死,根本不会.   首先考虑式子\(a+b=ab\),我们取\(a\)与\(b\)的\(gcd\):\(d\),那么式子就可以改写成: \[(a'+b')*d=a'b' ...

  3. 「10.10」神炎皇(欧拉函数)·降雷皇(线段树,DP)·幻魔皇

    A. 神炎皇 很好的一道题,可能第一次在考场上遇到欧拉函数 题意:对于一个整数对 $(a,b)$,若满足 $a\times b\leq n$且$a+b$是$a\times b$的因子, 则称为神奇的数 ...

  4. CSPS模拟 67

    炸分炸的厉害.(当然这跟b哥定律无关 话说好久没人嘲笑我菜了,快飘的不知道到哪了. 谁能讽我两句我不要面子的. 另外在博客上写些没用的东西好浪费精力啊我又不想当网红 主要是考试的时候心态不稳. 以为T ...

  5. csps模拟85表达式密码,电压机制,括号密码题解

    题面:https://www.cnblogs.com/Juve/articles/11733280.html 表达式密码: 是个水题... #include<iostream> #incl ...

  6. csp-s模拟48,49 Tourist Attractions,养花,画作题解

    题面:https://www.cnblogs.com/Juve/articles/11569010.html Tourist Attractions: 暴力当然是dfs四层 优化一下,固定两个点,答案 ...

  7. [CSP-S模拟测试]:降雷皇(DP+树状数组)

    题目描述 降雷皇哈蒙很喜欢雷电,他想找到神奇的电光.哈蒙有$n$条导线排成一排,每条导线有一个电阻值,神奇的电光只能从一根导线传到电阻比它大的上面,而且必须从左边向右传导,当然导线不必是连续的.哈蒙想 ...

  8. 【NOIP2017提高组模拟12.10】神炎皇

    题目 神炎皇乌利亚很喜欢数对,他想找到神奇的数对. 对于一个整数对(a,b),若满足a+b<=n且a+b是ab的因子,则成为神奇的数对.请问这样的数对共有多少呢? 分析 设\(gcd(a,b)= ...

  9. 【JZOJ4919】【NOIP2017提高组模拟12.10】神炎皇

    题目描述 神炎皇乌利亚很喜欢数对,他想找到神奇的数对. 对于一个整数对(a,b),若满足a+b<=n且a+b是ab的因子,则成为神奇的数对.请问这样的数对共有多少呢? 数据范围 对于100%的数 ...

随机推荐

  1. Jsoup 学习笔记

    这里写自定义目录标题 Jsoup 学习笔记 解析 HTML 的字符串解析 URL 解析 本地文件解析 解析数据 DOM 解析 使用选择器解析 选择器概述 选择器组合用法 过滤用法 修改数据 HTML ...

  2. 打包的@font-face包

    在网页中使用 @font-face 规则嵌入字体,前提是可以从你的网站或第三方 Web 服务器下载到相应的字体.以这种方式提供的字体,会在使用该字体的页面第一次加载时被浏览器下载并缓存起来,以后就不用 ...

  3. Git查看历史记录的几种方法

  4. lunix查询jdk安装路径

    在linux系统查找jdk的安装路径:whereis javawhich java (java执行路径)echo $JAVA_HOME echo $PATH在windows查找jdk的安装路径:set ...

  5. mysql UDF提权问题

    测试UDF提权,时候遇到问题,创建函数shell提示存在 当执行操作的时候又提示,shell函数不存在. FUNCTION mysql.shell does not exist 如果在测试环境下,一般 ...

  6. JS对象 indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。

    返回指定的字符串首次出现的位置 indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置. 语法 stringObject.indexOf(substring, startpos) 参 ...

  7. delphi 用户可以点击格式修改进行模板修改

    过程 TlistRepAdd.Btn_GCListRepEditClick窗口 TlistRepAdd 补打流程单 1. 给用户权限 呈现出格式修改按钮 procedure TlistRepAdd.B ...

  8. SUBTRACT

    SUBTRACT 给出一个长度为n序列\(\{a_i\}\),定义一个操作,记做\(con(a,i)\),意思是用\(a_i-a_{i+1}\)替代\(a_i,a_{i+1}\),显然最后一个数字不能 ...

  9. [转]nginx简易教程

    安装 nginx官网下载地址 发布版本分为 Linux 和 windows 版本. 也可以下载源码,编译后运行. 从源代码编译 Nginx 把源码解压缩之后,在终端里运行如下命令: $ ./confi ...

  10. String str = new String("abc"),这段代码一共生成了几个String对象?为什么?

    String str = new String("abc")创建了俩个对象,首先为创建一个String对象"abc",然后在调用String类的构造方法时 pu ...