题面: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. MyBatis中使用RowBounds对查询结果集进行分页

    MyBatis可以使用RowBounds逐页加载表数据.RowBounds对象可以使用offset和limit参数来构建.参数offset表示开始位置,而limit表示要取的记录的数目 映射文件: & ...

  2. python的update方法

    b = {"c":0, "position":{}} b["position"]["IF"] = {} print(b) ...

  3. Laravel 迁移检查表是否存在

    Schema::hasTable('TableName'); //检查表释放存在 Schema::hasColumn('tableName', 'columeName'); //检查表是否存在某个字段 ...

  4. R语言 数据重塑

    R语言数据重塑 R语言中的数据重塑是关于改变数据被组织成行和列的方式. 大多数时间R语言中的数据处理是通过将输入数据作为数据帧来完成的. 很容易从数据帧的行和列中提取数据,但是在某些情况下,我们需要的 ...

  5. xkl的各种沙雕低错

    13,特判判掉20分算不算? 12,linux用c++11编译: g++ -std=c++11 -o a a.cpp g++ a.cpp -std=c++11 -o a //g++ a.cpp -st ...

  6. java反射获取和设置实体类的属性值 递归所有父类

    最近做一个通用数据操作接口,需要动态获取和设置实体类的属性值,为了通用实体做了多重继承,开始网上找到代码都不支持父类操作,只能自己搞一个工具类了,此工具类可以设置和获取所有父类属性,代码贴下面拿走不谢 ...

  7. SP1296 SUMFOUR - 4 values whose sum is 0

    传送门 解题思路 四个数组一起做有点炸.先把他们合并成两个数组,然后让一个数组有序,枚举另一个数组的元素,二分即可.时间复杂度\(O(n^2logn^2)\) 代码 #include<iostr ...

  8. LUOGU P3413 SAC#1 - 萌数(数位dp)

    传送门 解题思路 首先这道题如果有两个以上长度的回文串,那么就一定有三个或两个的回文串,所以只需要记录一下上一位和上上位填的数字就行了.数位\(dp\),用记忆化搜索来实现.设\(f[i][j][k] ...

  9. VS2010-MFC(文档、视图和框架:分割窗口)

    转自:http://www.jizhuomi.com/software/226.html 上一节讲了文档.视图和框架结构中各对象之间的关系,本节主要讲讲在MFC中如何分割窗口. 分割窗口概述      ...

  10. Delphi代码创建形式规范 1.0

                Delphi代码创建形式规范 1.0 本规范的目的:给自己的代码一个统一而标准的外观,增强 可读性,可理解性,可维护性 本规范的原则:名称反映含义,形式反映结构 1.单元风格 ...