T1

看起来十分复杂,打表后发现答案是 \(n*m\mod p\)

具体的证明。。。

原式的物理意义,就是从坐标原点(0,0),用每一种合法的斜率,

穿过坐标[1 ~ n , 1 ~ m]的方阵中的整点的个数,总数即 n*m。

T2

考试时没想到 \(O(n^2)\) 的做法

\[\begin{aligned}
A_{k+i-1}-B_i &=A_{k+j-1}-B_j \\
A_{k+i-1}-A_{k+j-1} &= B_i-B_j \\
A_i-A_j &= B_i-B_j
\end{aligned}
\]

所以只要先差分,再跑一边 \(\text{KMP}\) 或字符串哈希即可

字符串哈希

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=1000005;
const LL M1=998244353,M2=1004535809,B=233;
int n,m,ans;
LL X1[N],X2[N],P1[N],P2[N],Y1,Y2,x[N],y[N];
inline bool check(int i) {
return
(Y1+1LL*P1[m]*X1[i-1]%M1)%M1==X1[i+m-1] &&
(Y2+1LL*P2[m]*X2[i-1]%M2)%M2==X2[i+m-1];
}
int main() {
freopen("sequence.in","r",stdin);
freopen("sequence.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)scanf("%lld",&x[i]);
for(int i=1;i<=m;i++)scanf("%lld",&y[i]);
for(int i=1;i<n;i++)x[i]=x[i+1]-x[i],x[i]+=2e9;
for(int i=1;i<m;i++)y[i]=y[i+1]-y[i],y[i]+=2e9;
--n,--m;
P1[0]=P2[0]=1;
for(int i=1;i<=n;i++) {
X1[i]=(1LL*X1[i-1]*B%M1+1LL*x[i])%M1;
X2[i]=(1LL*X2[i-1]*B%M2+1LL*x[i])%M2;
P1[i]=(1LL*P1[i-1]*B)%M1;
P2[i]=(1LL*P2[i-1]*B)%M2;
}
for(int i=1;i<=m;i++) {
Y1=(1LL*Y1*B%M1+1LL*y[i])%M1;
Y2=(1LL*Y2*B%M2+1LL*y[i])%M2;
}
for(int i=1;i<=n-m+1;i++)
if(check(i))++ans;
printf("%d",ans);
}

\(\text{KMP}\)

#include<bits/stdc++.h>
using namespace std;
const int N=1000005;
int n,m,ans,x[N],y[N],nxt[N];
int main() {
freopen("sequence.in","r",stdin);
freopen("sequence.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)scanf("%d",&x[i]);
for(int i=1;i<=m;i++)scanf("%d",&y[i]);
for(int i=1;i<n;i++)x[i]=x[i+1]-x[i];
for(int i=1;i<m;i++)y[i]=y[i+1]-y[i];
--n,--m;
for(int i=2,j=0;i<=m;i++) {
while(j && y[i]!=y[j+1])j=nxt[j];
if(y[i]==y[j+1])++j;
nxt[i]=j;
}
for(int i=0,j=0;i<=n;i++) {
while(j && x[i]!=y[j+1])j=nxt[j];
if(x[i]==y[j+1])++j;
if(j==m)++ans,j=nxt[j];
}
printf("%d",ans);
}

T3

考试时:不考虑 \(k\) 直接树形 DP ,奇妙地拿了 30

赛后:由于原题意思就是不能直接地祖孙关系,因为一个子树地 DFS 序是连续的

只要选的区间不相交即可,用 DP 解决

设 \(dp_{i,j}\) 为第 \(j\) 个果子选了 DFS 序为 \(i\) 的节点的最大美味值

可以从 \(dp_{i+1,j}\) ,\(dp_{\text{next subtree},j}\) ,和 \(dp_{\text{next subtree},j-1}+w_{\text{node of i}}\) 转移

数据十分奇妙,要开滚动数组。

#include<bits/stdc++.h>
using namespace std;
const int N=100005;
int n,k,op,dp[N][2],f[N],w[N],to[N],lst[N],nxt[N],rk[N],sz[N],odd,ans;
void Pre(int u) {
rk[++odd]=u,sz[u]=1;
for(int i=lst[u],v;i;i=nxt[i])
Pre(v=to[i]),sz[u]+=sz[v];
}
int main() {
freopen("galo.in","r",stdin);
freopen("galo.out","w",stdout);
scanf("%d%d",&n,&k),++k;
for(int i=2;i<=n;i++) {
scanf("%d%d",&f[i],&w[i]);
to[i]=i,nxt[i]=lst[f[i]];
lst[f[i]]=i;
}
Pre(1);
for(int C=1,j=0;C<=k;C++,j^=1) {
for(int i=n;i>=1;i--)
dp[i][j]=max(dp[i+1][j],max(dp[i+sz[rk[i]]][j],dp[i+sz[rk[i]]][j^1]+w[rk[i]]));
ans=max(ans,dp[1][j]);
}
printf("%d",ans);
}

T4

好家伙,看到子树修改,本蒟蒻直接一个树剖,好吧看错题+爆栈直接 WA 10

正解:直接 BFS 即可,设 \(F_i\) 为从根到这个点有多少个打了标记,若 \(F_i+Color_i\) 是偶数就不用翻转

#include<bits/stdc++.h>
using namespace std;
inline int Rd() {
register int x=0;
char C=getchar();
for(;C<'0'||C>'9';C=getchar()) ;
for(;C>'/'&&C<':';C=getchar()) x=(x<<1)+(x<<3)+(C^48);
return x;
}
const int N=500005;
int n,x[N],vis[N],lst[N],nxt[N],to[N],f[N],q[N],head,tail=1;
int main() {
freopen("tree.in","r",stdin);
freopen("tree.out","w",stdout);
n=Rd();
for(int i=1;i<=n;i++)x[i]=Rd();
for(int i=1,fr;i<n;i++) {
fr=Rd(),to[i]=Rd();
nxt[i]=lst[fr],lst[fr]=i;
}
q[1]=1;
for(int u,flg;head<tail;) {
u=q[++head],flg=(f[u]+x[u])&1;
if(flg)vis[u]=1;
for(int i=lst[u],v;i;i=nxt[i])
f[v=to[i]]=f[u]+flg,q[++tail]=v;
}
for(int i=1;i<=n;i++)
if(vis[i])printf("%d ",i);
}

总结

T1:学会打表

T2:多去把式子转换一下

T3:子树修改就想想 DFS 序,多考虑转换成 DP

T4:不一味的想数据结构,考虑简化

2021.03.06【NOIP提高B组】模拟 总结的更多相关文章

  1. 5820. 【NOIP提高A组模拟2018.8.16】 非法输入(模拟,字符串)

    5820. [NOIP提高A组模拟2018.8.16] 非法输入 (File IO): input:aplusb.in output:aplusb.out Time Limits: 1000 ms   ...

  2. 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  ...

  3. 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 ...

  4. 2021.04.03【NOIP提高B组】模拟 总结

    T1 题目大意:求最小的 \(n\in[0,lim]\) 使得区间 \([L,R]\) 在线段树建树 \(build(0,n)\) 的区间内 考场时想到了正解,结果推式子退错了... 其实就是从下往上 ...

  5. 2021.05.03【NOIP提高B组】模拟 总结

    比较水的一场比赛,却不能 AK T1 有 \(n\) 次,每次给 \(A_i,B_i\) 问以 \(i\) 结尾的 \(A,B\) 的匹配中最大和的最小值 问最大和的最小值,却不用二分. 如果暴力排序 ...

  6. [JZOJ5817] 【NOIP提高A组模拟2018.8.15】 抄代码

    Description J 君是机房的红太阳,每次模拟她总是 AK 虐场.然而在 NOIP2117 中,居然出现了另一位 AK 的选手 C 君! 这引起了组委会的怀疑,组委会认为 C 君有抄袭 J 君 ...

  7. [JZOJ5818] 【NOIP提高A组模拟2018.8.15】 做运动

    Description 一天,Y 君在测量体重的时候惊讶的发现,由于常年坐在电脑前认真学习,她的体重有了突 飞猛进的增长. 幸好 Y 君现在退役了,她有大量的时间来做运动,她决定每天从教学楼跑到食堂来 ...

  8. 【NOIP提高A组模拟2018.8.14】 区间

    区间加:差分数组修改 O(n)扫描,负数位置单调不减 #include<iostream> #include<cstring> #include<cstdio> # ...

  9. [jzoj 5782]【NOIP提高A组模拟2018.8.8】 城市猎人 (并查集按秩合并+复杂度分析)

    传送门 Description 有n个城市,标号为1到n,修建道路花费m天,第i天时,若gcd(a,b)=m-i+1,则标号为a的城市和标号为b的城市会建好一条直接相连的道路,有多次询问,每次询问某两 ...

  10. [jzoj 5781]【NOIP提高A组模拟2018.8.8】秘密通道 (最短路)

    传送门 Description 有一副nm的地图,有nm块地,每块是下列四种中的一种: 墙:用#表示,墙有4个面,分别是前面,后面,左面,右面. 起点:用C表示,为主角的起点,是一片空地. 终点:用F ...

随机推荐

  1. Java实现单链表的合并(保证数据的有序性)

    一.思路 1.比较两个链表的大小 2.将小链表插入到大链表中 3.使用插入保证链表数据的有序性 二.核心代码 /** * 合并两个链表,并且按照有序合并 * @param singleLinkedLi ...

  2. Shiro+springboot+mybatis(md5+salt+散列)认证与授权-02

    代码延续地址:Shiro+springboot+mybatis(md5+salt+散列)认证与授权-01 1.创建t_role角色表(比如管理员admin,普通用户user等),创建t_pers权限表 ...

  3. MySql创建分区

    一.Mysql分区类型 1.RANGE 分区:基于属于一个给定连续区间的列值,把多行分配给分区. 2.HASH分区:基于用户定义的表达式的返回值来进行选择的分区,该表达式使用将要插入到表中的这些行的列 ...

  4. HTML中的Hack手段之条件注释

    通常WEB的好处就是可以跨平台,但这个世界偏偏有个另类,就是IE浏览器.在平常做HTML设计时,有时需要为IE的表示差异而不得不使用一些Hack手段.条件注释就是这类手段之一. 条件注释是IE浏览器的 ...

  5. 利用java反射机制实现List>转化为List

    BEGIN; 最近在用hibernate做项目,由于后续的业务功能比较多,然后框架原设计没有使用到一对多.一对一等特性,(艹TA妹)没办法,只能用原生sql语句获得需要的结果集.但是返回过来的是一个L ...

  6. CSS一个较为完整的页面布局_可以根据页面屏幕大小调整布局

    1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...

  7. 使用 shell 脚本自动获取发版指标数据

    问题背景 大一点的公司都会建立一套规章流程来避免低级错误,例如合入代码前必需经过同行评审:上线前必需提测且通过 QA 验证:全量前必需经过 1%.5%.10%.20%.50% 的灰度过程.尤其是最后一 ...

  8. Day 001:PAT练习--1091 N-自守数 (15 分)

      体验了一阵子现代生活后,朕发现敲代码还是挺有意思的.所以从今天开始,小编秦始皇开始记录朕做PAT题目的过程辣,那话不多说,开始今天的题目了: 题目描述:   如果某个数 K 的平方乘以 N 以后, ...

  9. FreeRTOS --(4)内存管理 heap3

    转载自 https://blog.csdn.net/zhoutaopower/article/details/106677144 heap3 来说,是直接使用了 malloc 和 free 来直接替代 ...

  10. 99乘法表 java for循环

    public static void main(String[] args) { //0-100的奇数和偶数和 int jsum=0; int osum=0; for (int i = 0; i &l ...