题面: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. 2019 牛客多校第一场 E ABBA

    题目链接:https://ac.nowcoder.com/acm/contest/881/E 题目大意 问有多少个由 (n + m) 个 ‘A’ 和 (n + m) 个 ‘B’,组成的字符串能被分割成 ...

  2. jquery操作html元素之(设置内容和属性)

    设置内容 - text().html() 以及 val() 我们将使用前一章中的三个相同的方法来设置内容: text() - 设置或返回所选元素的文本内容 html() - 设置或返回所选元素的内容( ...

  3. 移动端dialog组件

    移动端dialog组件 dialogView是满足移动端下,用户自定义的dialog组件,API可扩展性强,使用便捷.现版本是基于jquery库编写的,在使用之前需要引入jquery库或者Zepto库 ...

  4. Docker学习のDocker初识

    一.Docker是什么 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然 ...

  5. 如何收集项目日志统一发送到kafka中?

    上一篇(http://qindongliang.iteye.com/blog/2354381 )写了收集sparkstreaming的日志进入kafka便于后续收集到es中快速统计分析,今天就再写一篇 ...

  6. Pod 私有仓库构建

    Pod 私有仓库构建 创建`私有仓库索引库`(iOS) 添加`私有仓库索引库`到本地repo管理 创建自己的`组建库工程 上传`组建库工程`到`私有仓库索引库` App工程调用`组建库工程` 目的 私 ...

  7. 笔记:简单的面向对象-web服务器

    import socket import re import multiprocessing import time import mini_frame class WSGIServer(object ...

  8. mac NTFS 关于错误-36,rm Input/output error

    当传输文件时出现Mac错误代码36 当我向一个U盘或存储卡里传输文件时,出现了Mac Error Code36,我该如何解决? Mac,传输文件,错误代码36,U盘,卡片 Mac OS X Snow ...

  9. JS对象 字符串分割 split() 方法将字符串分割为字符串数组,并返回此数组。 语法: stringObject.split(separator,limit)

    字符串分割split() 知识讲解: split() 方法将字符串分割为字符串数组,并返回此数组. 语法: stringObject.split(separator,limit) 参数说明: 注意:如 ...

  10. Window sevice +OWIN+webapi

    webapi正常都托管在iis上,这里引入owin,将其托管在window服务上. 第一步:创建一个服务,这里就不多描述. 第二步:引入OWIN 2.1引入bll 2.2加入api路由配置 publi ...