2021.06.05【NOIP提高B组】模拟 总结
T1
题意:给你一个 \(n\) 个点 \(n\) 条边的有向图,
求每个店经过 \(K\) 条边后的边权和、最小边权
\(K\le 10^{10}\)
考试时:一直想着环,结果一直不知道怎么做
正解:倍增预处理出经过 \(2^r\) 条边的终点和最大值、最小值
然后直接查询即可
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=100005;
int n,up,to[N][40],mn[N][40],mnn;
LL sm[N][40],K,sum,tmp;
int main() {
scanf("%d%lld",&n,&K),up=log2(K)+1;
for(int i=0;i<n;i++)scanf("%d",&to[i][0]);
for(int i=0;i<n;i++)scanf("%d",&mn[i][0]),sm[i][0]=1LL*mn[i][0];
for(int j=1;j<=up;j++)
for(int i=0;i<n;i++) {
to[i][j]=to[to[i][j-1]][j-1];
mn[i][j]=min(mn[i][j-1],mn[to[i][j-1]][j-1]);
sm[i][j]=sm[i][j-1]+sm[to[i][j-1]][j-1];
}
for(int i=0,u;i<n;i++) {
u=i,tmp=K,sum=0,mnn=INT_MAX;
for(int j=up;~j;j--) {
if(tmp>=(1ll<<j)) {
sum+=sm[u][j];
mnn=min(mnn,mn[u][j]);
u=to[u][j];
tmp-=(1ll<<j);
}
}
printf("%lld %d\n",sum,mnn);
}
}
T2
题意:求 \(n\) 所有的原根,如果 \(Ord_n(a)=\varphi(n)\) 则 \(a\) 是 \(n\) 的原根
其中 \(Ord_n(a)\) 是满足 \(a^d\equiv 1\pmod n\) 的最小的 \(d\)
比赛时:直接暴力,但是怕超时改了范围,结果 Wa
#include<bits/stdc++.h>
using namespace std;
int gcd(int a,int b) {
return b?gcd(b,a%b):a;
}
int n,rh,fl;
inline int Ord(int a) {
register int b=1;
for(int i=1;i<=rh;i++) {
b=b*a%n;
if(b==1%n)return i;
}
return -1;
}
int main() {
freopen("math.in","r",stdin);
freopen("math.out","w",stdout);
scanf("%d",&n);
for(int i=1;i<=n;i++)
rh+=(gcd(i,n)==1);
for(int i=1;i<=n;i++)
if(gcd(i,n)==1 && Ord(i)==rh)
printf("%d\n",i),fl=1;
if(!fl)puts("-1");
}
T3
题意:给你一颗有根树,保证一个点除了根节点以外的点都有唯一父亲
问有多少棵子树满足里面的结点是个连续的区间
考试:记录子树的最大值和最小值,然后用判断个数是否等于 \(mx-mn+1\)
正解:就是如此
细节炸了
#include<bits/stdc++.h>
using namespace std;
const int N=100005;
int n,ans,sz[N],mn[N],mx[N],rd[N],lst[N],nxt[N<<1],to[N<<1],cnt;
inline void Ae(int fr,int go) { to[++cnt]=go,nxt[cnt]=lst[fr],lst[fr]=cnt; }
void dfs(int u,int f) {
mn[u]=mx[u]=u,sz[u]=1;
for(int i=lst[u],v;i;i=nxt[i])
if((v=to[i])^f) {
dfs(v,u);
mn[u]=min(mn[u],mn[v]);
mx[u]=max(mx[u],mx[v]);
sz[u]+=sz[v];
}
if(sz[u]==mx[u]-mn[u]+1)
++ans;
}
int main() {
scanf("%d",&n);
for(int i=1,u,v;i<n;i++) {
scanf("%d%d",&u,&v);
Ae(u,v),++rd[v];
}
for(int i=1;i<=n;i++)
if(!rd[i]) { dfs(i,i); break; }
printf("%d",ans);
}
T4
题意:一个长度为 \(n\) 的排列,可以用 \(n-1\) 的字符串表示。
对于相邻的两个数,
如果前面的数比后面的大,则这个位置是上升的,记为 I
反之,这个位置下降,记为 D
现在给你一个包含 I, D 和 ? 的字符串,其中 ? 表示任意
问满足条件的排列个数
考试:设 \(f_{i,j,k}\) 表示第 \(i\) 位放了 \(j\) ,状态为 \(k\) 的个数
调不出来放弃
正解:设 \(f_{i,j}\) 为第 \(i\) 位放了 \(j\) 的个数
如果第 \(i\) 位是 I ,\(f_{i,j}=\sum_{k=1}^{j-1}f_{i-1,k}\)
其他的同理。
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL P=1000000007;
const int N=1005;
int n,ans;
LL s[N][N],f[N][N];
char st[N];
int main() {
scanf("%s",st+1);
n=strlen(st+1)+1;
f[1][1]=s[1][1]=1;
for(int i=2;i<=n;i++) {
for(int j=1;j<=i;j++) {
if(st[i-1]=='I')f[i][j]=s[i-1][j-1]%P;
else if(st[i-1]=='D')
f[i][j]=(s[i-1][i-1]-s[i-1][j-1]+P)%P;
else f[i][j]=s[i-1][i-1]%P;
(s[i][j]=s[i][j-1]+f[i][j])%=P;
}
}
printf("%lld",s[n][n]);
}
总结
T1:对于特别大的考虑倍增、二分等 \(\log\) 级的
T2:认真看题
T3:不要想太多
T4:状态转移需要简略、完整
2021.06.05【NOIP提高B组】模拟 总结的更多相关文章
- 5820. 【NOIP提高A组模拟2018.8.16】 非法输入(模拟,字符串)
5820. [NOIP提高A组模拟2018.8.16] 非法输入 (File IO): input:aplusb.in output:aplusb.out Time Limits: 1000 ms ...
- JZOJ 5818. 【NOIP提高A组模拟2018.8.15】 做运动
5818. [NOIP提高A组模拟2018.8.15] 做运动 (File IO): input:running.in output:running.out Time Limits: 2000 ms ...
- JZOJ 5812. 【NOIP提高A组模拟2018.8.14】 区间
5812. [NOIP提高A组模拟2018.8.14] 区间 (File IO): input:range.in output:range.out Time Limits: 1000 ms Memo ...
- 2021.03.06【NOIP提高B组】模拟 总结
T1 看起来十分复杂,打表后发现答案是 \(n*m\mod p\) 具体的证明... 原式的物理意义,就是从坐标原点(0,0),用每一种合法的斜率, 穿过坐标[1 ~ n , 1 ~ m]的方阵中的整 ...
- [JZOJ5817] 【NOIP提高A组模拟2018.8.15】 抄代码
Description J 君是机房的红太阳,每次模拟她总是 AK 虐场.然而在 NOIP2117 中,居然出现了另一位 AK 的选手 C 君! 这引起了组委会的怀疑,组委会认为 C 君有抄袭 J 君 ...
- [JZOJ5818] 【NOIP提高A组模拟2018.8.15】 做运动
Description 一天,Y 君在测量体重的时候惊讶的发现,由于常年坐在电脑前认真学习,她的体重有了突 飞猛进的增长. 幸好 Y 君现在退役了,她有大量的时间来做运动,她决定每天从教学楼跑到食堂来 ...
- 【NOIP提高A组模拟2018.8.14】 区间
区间加:差分数组修改 O(n)扫描,负数位置单调不减 #include<iostream> #include<cstring> #include<cstdio> # ...
- [jzoj 5782]【NOIP提高A组模拟2018.8.8】 城市猎人 (并查集按秩合并+复杂度分析)
传送门 Description 有n个城市,标号为1到n,修建道路花费m天,第i天时,若gcd(a,b)=m-i+1,则标号为a的城市和标号为b的城市会建好一条直接相连的道路,有多次询问,每次询问某两 ...
- [jzoj 5781]【NOIP提高A组模拟2018.8.8】秘密通道 (最短路)
传送门 Description 有一副nm的地图,有nm块地,每块是下列四种中的一种: 墙:用#表示,墙有4个面,分别是前面,后面,左面,右面. 起点:用C表示,为主角的起点,是一片空地. 终点:用F ...
- [jzoj 5778]【NOIP提高A组模拟2018.8.8】没有硝烟的战争 (博弈论+dp)
传送门 Description 被污染的灰灰草原上有羊和狼.有N只动物围成一圈,每只动物是羊或狼. 该游戏从其中的一只动物开始,报出[1,K]区间的整数,若上一只动物报出的数是x,下一只动物可以报[x ...
随机推荐
- 微信小程序HTTP接口请求封装
1.方法封装(新建文件夹util,工具文件,在文件夹下创建request.js文件,用于对方法封装)request.js: var app = getApp(); //项目URL相同部分,减轻代码量, ...
- vue中图片预览(v-viewer库使用)
效果图: 注释: 可拖拽,可放大缩小旋转,全屏,功能齐全,底部有操作按钮 属性: npm install v-viewer --save //安装 //在main.js中引入 import Vie ...
- vue里面v-for显示红色波浪线
vue里面使用v-for代码显示红色的波浪线,解决办法: before: <div v-for="tmsgs in msg.message"></div> ...
- FastAPI(六十六)实战开发《在线课程学习系统》接口开发--用户注册接口开发
在前面我们分析了接口的设计,那么我们现在做接口的开发. 我们先去设计下pydantic用户参数的校验 from pydantic import BaseModel from typing import ...
- Unable to negotiate with xx.xxx.xxxx port 22: no matching host key type found. Their offer: ssh-rsa(解决的两种方式)
异常问题: 下班之前升级了一下Git的版本,结果第二天过来拉取远程最新代码的时候就提示了下面的异常问题: Unable to negotiate with xx.xxx.xxxx port 22: n ...
- Java报错: A component required a bean of type 'com.sirifeng.testmybatis.mapper.BookMapper' that could not be found.
在学习Spring-boot-mybatis时,报错A component required a bean of type 'com.sirifeng.testmybatis.mapper.BookM ...
- coolshell-初见
首页:https://coolshell.cn/tag/programmer 我是怎么招聘程序员的 https://coolshell.cn/articles/1870.html 程序员需要具备的基本 ...
- 【面试普通人VS高手系列】谈谈你对Seata的理解
很多面试官都喜欢问一些"谈谈你对xxx技术的理解". 大家遇到这种问题时,是不是完全不知道从何说起. 那么我们来看一下,普通人和高手是如何回答这个问题的? 普通人: Seata是用 ...
- k8s 初始化环境(1)
概念 k8s/kubernetes 容器化部署 解决容器编排问题,kubernetes为容器编排软件的佼佼者 kubernets为一组服务器集群 功能 自我修复 一个容器崩溃,另一个容器起来 弹性伸缩 ...
- Mysql学习day1
安装了Mysql以及SQLyog,将SQLyog和数据库做了连接. 学习了基础数据类型以及命令行语句 1 alter table `student` rename as `stu``lesson` 2 ...