\(noip模拟26\;solutions\)

这个题我做的确实是得心应手,为啥呢,因为前两次考试太难了

T1非常的简单,只不过我忘记了一个定理,

T2就是一个小小的线段树,虽然吧我曾经说过我再也不写树状数组了,但是我看见最长上升子序列就兴奋了

码了个树状数组就溜走了,用时仅为10min,60pts,组合拳

T3我就是nb

\(T1\;神炎皇\)

这个就是一个小小的推式子,让我给你推一推

\(a+b\,|\, a*b\),设\(d=gcd(a,b),x=a/d,y=b/d\),所以x和y互质

我们有\(k*(x+y)\,|\,x*y*d^2<====>(x+y)\,|\,x*y*d\)

因为x,y互质所以(x+y)| d,设(x+y)=k

\(k*d<=n并且k\,|\,d并且k<{d}\),所以这样的d一共有\(\frac{n}{k^2}\)个

这种x与y互质,x+y为定值,你发现x与x+y也是互质的,所以每一个k对应的x+y都有\(\phi(k)\)

k的范围是\(\sqrt{n}\)

那么接下来的事就只剩下线性筛了;

AC_code

#include<bits/stdc++.h>
using namespace std;
#define re register int
#define ll long long
const int N=1e7+5;
ll n,ans,sn;
int p[N],cnt,f[N];
bool vis[N];
signed main(){
scanf("%lld",&n);
sn=sqrt(n);
//memset(vis,1,sizeof(vis));
//cout<<vis[1]<<endl;
for(re i=2;i<=sn;i++){
if(!vis[i])p[++cnt]=i,f[i]=i-1;
for(re j=1;j<=cnt&&p[j]*i<=sn;j++){
vis[p[j]*i]=true;
if(i%p[j]==0){
f[i*p[j]]=f[i]*p[j];
break;
}
else f[i*p[j]]=f[i]*f[p[j]];
}
}
for(re i=1;i<=sn;i++){
ans+=f[i]*(n/i/i);
}
printf("%lld",ans);
}


\(T2\;降雷皇\)

这个题真的是简单极了,我也没想到会有这么简单的题,打了个60分的组合拳就走了

最后发现这个用线段树维护一下就好了

毕竟是动态开点,而且这个电阻值只有1e5,完全不需要离散化,

对于每一种长度也就是最长上升子序列的长度建立一个线段树,

线段树的下标是电阻值,因为你查询的时候是按照电阻值来查询的

线段树中维护的权值即为方案数,这样遍历一遍这个序列,\(O(nlogn)\)就可以解决方案数了

最后直接输出最长长度的线段树的所有权值加和,说白了就是根节点的sum

AC_code

#include<bits/stdc++.h>
using namespace std;
#define re register int
const int N=1e5+5;
const int mod=123456789;
int n,typ,ans1,ans2;
int omu[N],f[N],sum[N];
struct SZSZ{
int tr[N];
int lb(int x){return x&(-x);};
void ins(int x,int v){
for(re i=x;i<=1e5;i+=lb(i))
tr[i]=max(tr[i],v);
}
int query(int x){
int ret=0;
for(re i=x;i;i-=lb(i))
ret=max(ret,tr[i]);
return ret;
}
}sz;
int dp[N];
struct XDS{
int ls[N*80],rs[N*80];
int sum[N*80];
int seg;
void pushup(int x){
sum[x]=(sum[ls[x]]+sum[rs[x]])%mod;
return ;
}
void ins(int &x,int l,int r,int pos,int v){
if(!x)x=++seg;
if(l==r){
sum[x]=(sum[x]+v)%mod;
return ;
}
int mid=l+r>>1;
if(pos<=mid)ins(ls[x],l,mid,pos,v);
else ins(rs[x],mid+1,r,pos,v);
pushup(x);return ;
}
int query(int x,int l,int r,int ql,int qr){
if(!x)return 0;
if(ql<=l&&r<=qr)return sum[x];
int mid=l+r>>1,ret=0;
if(ql<=mid)ret=(ret+query(ls[x],l,mid,ql,qr))%mod;
if(qr>mid)ret=(ret+query(rs[x],mid+1,r,ql,qr))%mod;
return ret;
}
}xds;
int rt[N];
signed main(){
scanf("%d%d",&n,&typ);
for(re i=1;i<=n;i++){
scanf("%d",&omu[i]);
dp[i]=sz.query(omu[i]-1)+1;
ans1=max(ans1,dp[i]);
sz.ins(omu[i],dp[i]);
//cout<<omu[i]<<" "<<dp[i]<<endl;
}
printf("%d\n",ans1);
if(typ==1){
int R=1e5+1,mn=0x3f3f3f3f;
for(re i=1;i<=n;i++){
int tmp=xds.query(rt[dp[i]-1],1,R,1,omu[i]-1);
if(mn>=omu[i]&&tmp==0)tmp=1,mn=omu[i];
xds.ins(rt[dp[i]],1,R,omu[i],tmp);
}
printf("%d",xds.query(rt[ans1],1,R,1,R));
}
}


\(T3\;幻魔皇\)

这整一棵树都充斥这非波那契数列,真的就直接倒就好了

其实还有更简单的\(O(n^2)\)做法还比我的简单,比我的快

去看别人的博客吧,我这个非常难理解,

主要思路就是,首先枚举每一层,每一层的黑色节点和白色节点的类型都是一样的

黑色节点直接枚举左右儿子就行,白色节点就是直接用自己连接自己子树中的白色节点

注意黑色子树中有一个不符合规律的,就是这个黑色节点的白儿子,把这个拎出来单独算

AC_code

#include<bits/stdc++.h>
using namespace std;
#define re register int
const int N=5e3+5;
const int mod=123456789;
int fb[N],ffb[N][N*2],ans[N*2],n;
signed main(){
scanf("%d",&n);
fb[1]=1;fb[2]=1;
for(re i=3;i<=5000;i++)
fb[i]=(fb[i-1]+fb[i-2])%mod;
for(re i=2;i<=n;i++){
for(re j=1;j<=2*n;j++)
ffb[i][j]=(ffb[i][j]+ffb[i-1][j])%mod;
for(re j=3;j<=n;j++){
//if(i==4&&j==3)cout<<ffb[j][i+j]<<" "<<i+j<<endl;
ffb[max(j,i)][i+j]+=1ll*fb[i-1]*fb[j-2]%mod;
ffb[max(j,i)][i+j]%=mod;
//if(i==4&&j==3)cout<<ffb[j][i+j]<<endl;
}
}
//cout<<ffb[4][7]<<endl;
for(re i=2;i<=n;i++){
for(re j=5;j<=2*(n-i);j++){
ans[j]+=1ll*fb[i-1]*ffb[n-i][j]%mod;
ans[j]%=mod;
}
for(re j=i+2;j<=n;j++){
ans[j-i+1]+=1ll*fb[i-1]*fb[j-i-1]%mod;
ans[j-i+1]%=mod;
}
for(re j=i+2;j<=n;j++){
ans[j-i]+=1ll*fb[i-2]*fb[j-i-1]%mod;
ans[j-i]%=mod;
}
}
for(re j=3;j<=n;j++){
ans[j-1]+=fb[j-2];
ans[j-1]%=mod;
}
for(re i=1;i<=2*n;i++)printf("%d ",ans[i]);
}


noip模拟26[肾炎黄·酱累黄·换莫黄]的更多相关文章

  1. [考试总结]noip模拟26

    首先看到这样中二的题目心头一震.... 然而发现又是没有部分分数的一天. 然而正解不会打.... 那还是得要打暴力. 但是这套题目有两个题目只有一个参数. 所以... (滑稽).jpg 然后我就成功用 ...

  2. 2021.7.28考试总结[NOIP模拟26]

    罕见的又改完了. T1 神炎皇 吸取昨天三个出规律的教训,开场打完T2 20pts直接大力打表1h. 但怎么说呢,我不懂欧拉函数.(其实exgcd都忘了 于是只看出最大平方因子,不得不线性筛,爆拿60 ...

  3. NOIP模拟 26

    我辛辛苦苦敲了3.5h的码 得分和一份8B的码一样多 自闭555. T1 marshland 最小费用可行流, 板子不会,建图更不会. 当然是用暴搜得到0分的好成绩啦 补了补板子. %了%RNB. 学 ...

  4. NOIP模拟26

    把题解沽了好久了,今天还是不想写,我们靠的B卷其实挺水的,但是我就是想吐槽一下!咋还带题目里面放题解的?题里一点题解的线索都没有,但是玄机竟然在题目里! 我也是醉了,T1就是一个贪心,题目说贪婪,T2 ...

  5. HZOJ 20190819 NOIP模拟26题解

    考试过程: 照例开题,然后觉得三道题都挺难,比昨天难多了(flag×1),T1 dp?T2 数据结构? T3 dp?事实证明我是sb然后决定先搞T2,但是,woc,这题在说什么啊,我怎么看不懂题啊,连 ...

  6. [NOIP模拟26]题解

    今天的考试题改自闭了……所以滚来写陈年题解. A.*****贪婪***** RT,出题人告诉我们这题要贪心. 最优的策略一定是拖到必须断的时候再断开(虽然并不知道为什么). 如果一段序列满足题目中的性 ...

  7. NOIP 模拟 $26\; \rm 幻魔皇$

    题解 \(by\;zj\varphi\) 观察可发现一个点向它的子树走能到的白点,黑点数是一个斐波那契数列. 对于白色点对,可以分成两种情况: 两个白点的 \(lca\) 是其中一个白点 两个白点的 ...

  8. NOIP 模拟 $26\; \rm 降雷皇$

    题解 \(by\;zj\varphi\) 用树状数组优化一下求最长上升子序列即可. 至于第二问,在求出答案后开 \(n\) 棵线段树,每颗维护当前最长上升子序列长度的方案数. Code #includ ...

  9. NOIP 模拟 $26\; \rm 神炎皇$

    题解 \(by\;zj\varphi\) 一道 \(\varphi()\) 的题. 对于一个合法的数对,设它为 \((a*m,b*m)\) 则 \(((a+b)*m)|a*b*m^2\),所以 \(( ...

随机推荐

  1. jquery给动态生成的元素绑定事件,on函数

    首先先解释一下什么是动态生成的元素:动态生成的元素即我们用jquery的内部插入函数append()所生成的html代码.相对的也有静态生成的元素:即直接编写在页面的html代码. 下面通过例子来讲解 ...

  2. springboot异常错误处理

    1.在有模板引擎的情况下: springboot会默认找 templates/error/错误状态码.html,所以我们要定制化错误页面就可以到templates/error下创建一个[对应错误状态码 ...

  3. 「题解」HDU-4015 Mario and Mushrooms

    本文将同步发布于: 洛谷博客: csdn: 博客园: 简书: 题目 题目链接:HDU-4015 Mario and Mushrooms.Vjudge HDU-4015. 题意简述 马里奥初始只有 \( ...

  4. PAT甲级 1093 Count PAT‘s (25 分) 状态机解法

    题目 原题链接 The string APPAPT contains two PAT's as substrings. The first one is formed by the 2nd, the ...

  5. redis为什么要提供pipeline功能

    通常我们用redis做接口缓存后,查询接口的性能就能提升到ms级别: 但是redis是纯内存操作啊,总不至于要到ms吧,根据官方的 benchmark 单实例也是能抗 7w+ qps 也就是说单个re ...

  6. 【题解】SOFTWARE 二分+搜索/dp

    题目描述 一个软件开发公司同时要开发两个软件,并且要同时交付给用户,现在公司为了尽快完成这一任务,将每个软件划分成m个模块,由公司里的技术人员分工完成,每个技术人员完成同一软件的不同模块的所用的天数是 ...

  7. 一文带你走遍Git世界,教会你Git的使用

    @ 目录 这篇文章教会Git 1. Git是什么? 1.1 发展历程 1.2 Git是什么? 1.3 Git和SVN 2.Git有什么用? 2.1 代码合并 2.2 代码备份 2.3 代码还原 2.4 ...

  8. centos7安装kubernetes1.18.5

    一.设置hosts 修改主机名 [root@localhost kubernetes]# hostnamectl set-hostname master69 四台服务器安装kebernetes,一个m ...

  9. match、vlookup、hlookup函数(结合index运用可以实现自动化填充)

    1.match返回查找值位置: match(lookup_value, lookup_array, match_type) Match(目标值,查找区域,0/1/-1) 使用注意:返回值是基于选择区域 ...

  10. 『动善时』JMeter基础 — 52、使用JMeter测试Dubbo接口

    目录 1.Dubbo介绍 2.准备测试Dubbo接口的环境 3.Dubbo Sample界面详解 4.Dubbo Sample组件的使用 (1)测试计划内包含的元件 (2)使用zookeeper协议请 ...