3.26省选模拟+NOI-ONLINE
今日趣闻:
这三个人都是同机房的,卡最优解(大常数选手不参与)....以至于最优解第一页都是我们机房的(有图为证,共三人)
$NOI\ online$
$T1$
首先模拟一遍记录这个点当前单调栈前面位置,然后线段树(主席树)查询多少下标小于某个数的
#include<bits/stdc++.h>
#define MAXN 500005
using namespace std;
struct Tree
{
int ls,rs,sum;
}tr[MAXN<<5];
struct node
{
int a,b;
}poz[MAXN];
int n,q,tot,top,rt[MAXN],sta[MAXN],wei[MAXN];
void Init()
{
top=0;
for(int i=1;i<=n;i++)
{
while(top&&(poz[sta[top]].a==poz[i].a||poz[sta[top]].b<=poz[i].b)) top--;
wei[i]=sta[top];
sta[++top]=i;
}
}
void build(int &now,int l,int r)
{
if(!now) now=++tot;
if(l==r) return ;
int mid=(l+r)>>1;
build(tr[now].ls,l,mid);
build(tr[now].rs,mid+1,r);
}
void Merge(int &rt1,int rt2,int l,int r,int poz)
{
rt1=++tot;
if(l==r)
{
tr[rt1].sum=tr[rt2].sum+1;
return ;
}
int mid=(l+r)>>1;
if(poz<=mid)
{
tr[rt1].rs=tr[rt2].rs;
Merge(tr[rt1].ls,tr[rt2].ls,l,mid,poz);
}
else
{
tr[rt1].ls=tr[rt2].ls;
Merge(tr[rt1].rs,tr[rt2].rs,mid+1,r,poz);
}
tr[rt1].sum=(tr[tr[rt1].ls].sum+tr[tr[rt1].rs].sum);
}
int query(int rt1,int rt2,int l,int r,int k)
{
if(l==r)
{
return tr[rt2].sum-tr[rt1].sum;
}
int mid=(l+r)>>1;
if(k<=mid) return query(tr[rt1].ls,tr[rt2].ls,l,mid,k);
else return (tr[tr[rt2].ls].sum-tr[tr[rt1].ls].sum)+query(tr[rt1].rs,tr[rt2].rs,mid+1,r,k);
}
int main()
{
scanf("%d%d",&n,&q);
for(int i=1;i<=n;i++) scanf("%d",&poz[i].a);
for(int i=1;i<=n;i++) scanf("%d",&poz[i].b);
Init();
build(rt[0],0,n);
for(int i=1;i<=n;i++)
{
Merge(rt[i],rt[i-1],0,n,wei[i]);
}
for(int i=1,res,l,r;i<=q;i++)
{
scanf("%d%d",&l,&r);
printf("%d\n",query(rt[l-1],rt[r],0,n,wei[l]));
}
}
$T2$
随机化吧,看种子呗(会正解的$dalao$们能不能私信教教我啊)
#include<bits/stdc++.h>
#define MAXN 1000005
using namespace std;
bool vis[MAXN];
vector<int>peo[MAXN];
int pf;
void sol()
{
int n;
scanf("%d",&n);
int Tim=n*20;
for(int i=1;i<=n;i++) peo[i].clear();
for(int i=1,num,poz;i<=n;i++)
{
scanf("%d",&num);
for(int j=1;j<=num;j++)
{
scanf("%d",&poz);
peo[i].push_back(poz);
}
}
srand(time(0));
int cnt;
bool flag=false;
while(Tim--)
{
int p1=rand()%n+1,p2=rand()%n+1;
if(peo[p1].size()>peo[p2].size()) swap(p1,p2);
for(int i=0;i<peo[p1].size();i++)
{
vis[peo[p1][i]]=true;
}
cnt=0;
for(int i=0;i<peo[p2].size();i++)
{
cnt+=(vis[peo[p2][i]]?1:0);
}
for(int i=0;i<peo[p1].size();i++)
{
vis[peo[p1][i]]=false;
}
if(cnt==peo[p1].size()) continue;
if(cnt==0) continue;
puts("YES");
printf("%d %d\n",p1,p2);
flag=true;
break;
}
if(!flag)
{
puts("NO");
}
}
int T;
int main()
{
scanf("%d",&T);
while(T--) sol();
}
$T3$
$KD-tree$四维偏序就好了,据说用$Min-Max$反演可以变为三维偏序(咕咕咕),貌似想复杂了(各位有什么简单方法啊)
上午模拟赛一直在罚坐...
模拟赛
打了一场模拟赛,又双叒叕垫底了
$T1$想了半天差分和网络流,没有分析出性质,还需要增强分析能力
$T2$设计状态出了问题,一直卡在了重合部分,在容斥里面没想出来
$T3$博弈论$kill$
$T1$
//首先考虑左下角和右上角操作是没用的
//所有的状态可以由1解决,而且代价小
//考场上想到了差分+网络流,其实没什么关系.
//考虑在矩阵上搞一搞事情,转化一下矩阵
//a[i][j]=(c[i][j]+c[i+1][j]+c[i][j+1]+c[i+1][j+1])%2;这不就是(奇怪的)差分吗...
//对于操作1,我们是翻转一个点,对于操作是,翻转(x,y)
//对于操作4,我们是翻转四个点,全是1我们才会翻转,而且只操作一次就好
//然后就很水了,这种结论题还是不怎么好整
#include<bits/stdc++.h>
#define INF 2147483647
#define int long long
#define MAXN 1000005
using namespace std;
int head[MAXN],nxt[MAXN],val[MAXN],to[MAXN],tot=1;
int Num[505][505];
char mp[505][505];
int dis[MAXN];
int n,m,opt,Ans;
queue<int>q;
void add(int u,int v,int w)
{
// cout<<"add: "<<u<<" "<<v<<endl;
tot++;
to[tot]=v;
val[tot]=w;
nxt[tot]=head[u];
head[u]=tot;
}
bool bfs(int s,int t)
{
// for(int i=1;i<=t;i++) dis[i]=-1;
memset(dis,-1,sizeof(dis));
dis[s]=0;
q.push(s);
while(!q.empty())
{
int now=q.front();
q.pop();
for(int i=head[now];i!=-1;i=nxt[i])
{
int y=to[i];
// cout<<"now: "<<now<<" "<<y<<endl;
// system("pause");
if(dis[y]!=-1||!val[i]) continue;
dis[y]=dis[now]+1;
q.push(y);
}
}
return dis[t]!=-1;
}
int dfs(int now,int ed,int flow)
{
if(now==ed) return flow;
int rest=flow;
for(int i=head[now];i!=-1;i=nxt[i])
{
int y=to[i];
if(dis[y]!=dis[now]+1||!val[i]) continue;
int k=dfs(y,ed,min(rest,val[i]));
val[i]-=k;
val[i^1]+=k;
rest-=k;
if(!k) dis[y]=-1;
}
return flow-rest;
}
signed main()
{
freopen("dream.in","r",stdin);
freopen("dream.out","w",stdout);
scanf("%d%d%d",&n,&m,&opt);
if(opt==0)
{
for(int i=1;i<=n;i++)
{
scanf("%s",mp[i]+1);
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
Num[i][j]=(mp[i][j]=='W'?0:1);
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
Num[i][j]+=Num[i+1][j]+Num[i][j+1]+Num[i+1][j+1];
Num[i][j]%=2;
}
}
bool flag=false;
for(int i=1;i<n;i++)
{
for(int j=1;j<m;j++)
{
if(Num[i][j]&&Num[n][j]&&Num[i][m]&&Num[n][m])
{
flag=true;
goto EB;
}
}
}
EB:;
int res=0;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
res+=Num[i][j];
}
}
if(!flag)
{
cout<<res;
}
else
{
cout<<(res-4)+3;
}
}
else
{
memset(head,-1,sizeof(head));
int S=n+m+1,T=n+m+2;
for(int i=1;i<=n;i++)
{
scanf("%s",mp[i]+1);
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
Num[i][j]=(mp[i][j]=='W'?0:1);
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
Num[i][j]+=Num[i+1][j]+Num[i][j+1]+Num[i+1][j+1];
Num[i][j]%=2;
}
}
for(int i=1;i<n;i++)
{
for(int j=1;j<m;j++)
{
if(Num[i][j]&&Num[n][j]&&Num[i][m])
{
add(i,j+n,1);
add(j+n,i,0);
// cout<<"add1: "<<i<<" "<<j+n<<endl;
}
}
}
for(int i=1;i<n;i++) add(S,i,1),add(i,S,0);
for(int i=1;i<m;i++) add(i+n,T,1),add(T,i+n,0);
int flow=0;
while(bfs(S,T))
{
flow+=dfs(S,T,INF);
}
Num[n][m]^=(flow&1);
int res=0;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
res+=Num[i][j];
}
}
cout<<res-flow;
}
}
$T2$
//考试时候想到了容斥,需要处理一堆东西
//首先有效区间不多,可以离散化
//其次关于最大值不同的区间,可以分别计数
//而且小的优先级更高,可以完全覆盖最大值大的区间
//问题转化也比较好说,首先分开考虑是必然的
//其次是,处理每一类最大值
//我们现在问题转化为一个区间必须有一个点为最大值
//大部分都很好说,就是那个区间重叠不会处理了
//先说没有重合的统计答案
//就是总方案-不合法的
//重合的话使用dp转移
//大概明白了,其实就是把有断点排序,找上一个区间染色
//然后枚举上一步决策,让这一步合法就好了
#include<bits/stdc++.h>
#define INF 2147483647
#define int long long
#define mod 998244353
#define MAXN 2005
using namespace std;
int T,n,Q,A;
struct Node
{
int l,r,L,R,m;
bool operator <(const Node &b)const
{
if(l!=b.l) return l<b.l;
else r<b.r;
}
}q[MAXN],seg[MAXN<<2];
int num,b[MAXN<<1],cnt,Min[MAXN<<1],f[MAXN<<1][MAXN<<1];;
bool cmp(Node x,Node y)
{
return x.m<y.m;
}
int my_pow(int a,int b)
{
int res=1;
while(b)
{
if(b&1)
{
res=res*a%mod;
}
a=a*a%mod;
b>>=1;
}
return res;
}
int calc(int x)
{
Node pos[MAXN<<1];
int tot=0,m=0,pl[MAXN<<1],pr[MAXN<<1];
for(int i=1;i<=num;i++)
{
if(Min[i]==x)
{
pos[++tot]=seg[i];
pl[++m]=seg[i].l;
pr[m]=seg[i].r;
}
}
if(tot==0) return -1;
sort(pl+1,pl+m+1);
sort(pr+1,pr+m+1);
int lim[MAXN];
for(int i=1;i<=tot;i++)
{
lim[i]=0;
}
for(int i=1;i<=Q;i++)
{
if(q[i].m==x)
{
int L=lower_bound(pl+1,pl+m+1,q[i].L)-pl,R=upper_bound(pr+1,pr+m+1,q[i].R)-pr-1;
lim[R]=max(lim[R],L);
}
}
f[0][0]=1;
for(int i=1;i<=tot;i++)
{
f[i][i]=0;
int base0=my_pow(x-1,pos[i].r-pos[i].l+1);
int base1=my_pow(x,pos[i].r-pos[i].l+1);
for(int j=0;j<i;j++)
{
if(j>=lim[i])
{
f[i][j]=f[i-1][j]*base0%mod;
}
else f[i][j]=0;
f[i][i]=(f[i][i]+f[i-1][j]*(base1-base0+mod)%mod)%mod;
}
}
int res=0;
for(int i=0;i<=tot;i++)
{
res=(res+f[tot][i])%mod;
}
return res;
}
unordered_map<int,int>book;
void solve()
{
scanf("%d%d%d",&n,&Q,&A);
cnt=0;
for(int i=1;i<=Q;i++)
{
scanf("%d%d%d",&q[i].l,&q[i].r,&q[i].m);
q[i].L=q[i].l,q[i].R=q[i].r;
b[++cnt]=q[i].l,b[++cnt]=q[i].r;
}
sort(b+1,b+cnt+1);
cnt=unique(b+1,b+cnt+1)-b-1;
num=0;
book.clear();
for(int i=1;i<=cnt;i++)
{
if(b[i-1]+1<=b[i]-1) seg[++num]={b[i-1]+1,b[i]-1,b[i-1]+1,b[i]-1,0};
seg[++num]={b[i],b[i],b[i],b[i],0},book[b[i]]=num;
}
if(seg[num].r!=n) seg[num+1]={seg[num].r+1,n,seg[num].r+1,n,0},num++;
for(int i=1;i<=Q;i++)
{
q[i].l=book[q[i].l],q[i].r=book[q[i].r];
}
memset(Min,63,sizeof(Min));
for(int i=1;i<=Q;i++)
{
for(int u=q[i].l;u<=q[i].r;u++)
{
Min[u]=min(Min[u],q[i].m);
}
}
set<int>S;
for(int i=1;i<=Q;i++)
{
S.insert(q[i].m);
}
int ans=1;
for(int x:S)
{
int res=calc(x);
if(res==-1)
{
printf("0\n");
return;
}
else ans=ans*res%mod;
}
for(int i=1;i<=num;i++)
{
if(Min[i]>A) ans=ans*my_pow(A,seg[i].r-seg[i].l+1)%mod;
}
printf("%lld\n",ans);
return;
}
signed main()
{
freopen("value.in","r",stdin);
freopen("value.out","w",stdout);
scanf("%d",&T);
while(T--) solve();
return 0;
}
$T3$
//神奇的博弈问题
//开始有一些地方有石子,每次选择满足条件p,q和一个位置
//在这个位置减去一个石子,其余位置加一个石子
//本题就是mod 2的情况下
//如果原来
#include <bits/stdc++.h>
#define MAXN 300005
using namespace std;
int n,q,SG[MAXN],cnt[350];
void sol(int x,int p,int w)
{
int c=0,y=x;
for(int i=1;i<=q;i++)
{
if(y%p!=0)
{
break;
}
y/=p;
c^=SG[y];
if(c<303)cnt[c]=x;
}
}
void GSG(int x)
{
for(int i=1,j=2;;i++)
{
if(x%j!=0) break;
sol(x,j,i);
j*=2;
}
for(int i=1,j=3;;i++)
{
if(x%j!=0) break;
sol(x,j,i);
j*=3;
}
for(int i=0;;i++)
{
if(cnt[i]!=x)
{
SG[x]=i;
return;
}
}
}
int main()
{
freopen("forward.in","r",stdin);
freopen("forward.out","w",stdout);
int T;
scanf("%d",&T);
for(int i=1,b=0,c=0;i<=T;i++)
{
c=0;
memset(cnt,0,sizeof(cnt));
scanf("%d%d",&n,&q);
for(int j=1;j<=n;j++)
{
GSG(j);
}
for(int j=1;j<=n;j++)
{
scanf("%d",&b);
if(b==0) c^=SG[j];
}
if(c==0) printf("lose\n");
else printf("win\n");
}
return 0;
}
3.26省选模拟+NOI-ONLINE的更多相关文章
- 4.26 省选模拟赛 T3 状压dp 差分求答案
LINK:T3 比较好的题目 考试的时候被毒瘤的T2给搞的心态爆炸 这道题连正解的思路都没有想到. 一看到题求删除点的最少个 可以使得不连通. 瞬间想到最小割 发现对于10分直接跑最小割即可. 不过想 ...
- 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解
今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...
- 【NOI省选模拟】小奇的花园
「题目背景」 小奇在家中的花园漫步时,总是会思考一些奇怪的问题. 「问题描述」 小奇的花园有n个温室,标号为1到n,温室以及以及温室间的双向道路形成一棵树. 每个温室都种植着一种花,随着季节的变换,温 ...
- [noi.ac省选模拟赛]第12场题解集合
题目 比赛界面. T1 数据范围明示直接\(O(n^2)\)计算,问题就在如何快速计算. 树上路径统计通常会用到差分方法.这里有两棵树,因此我们可以做"差分套差分",在 A 树上对 ...
- 省选模拟赛 4.26 T1 dp 线段树优化dp
LINK:T1 算是一道中档题 考试的时候脑残了 不仅没写优化 连暴力都打挂了. 容易发现一个性质 那就是同一格子不会被两种以上的颜色染.(颜色就三种. 通过这个性质就可以进行dp了.先按照左端点排序 ...
- NOI 2019 省选模拟赛 T1【JZOJ6082】 染色问题(color) (多项式,数论优化)
题面 一根长为 n 的无色纸条,每个位置依次编号为 1,2,3,-,n ,m 次操作,第 i 次操作把纸条的一段区间 [l,r] (l <= r , l,r ∈ {1,2,3,-,n})涂成颜色 ...
- NOI.AC省选模拟赛第一场 T1 (树上高斯消元)
link 很容易对于每个点列出式子 \(f_{x,y}=(f_{x,y-1}+f_{x,y}+f_{x,y+1}+f_{x+1,y})/4\)(边角转移类似,略) 这个转移是相互依赖的就gg了 不过你 ...
- [NOI.AC省选模拟赛3.31] 星辰大海 [半平面交]
题面 传送门 思路 懒得解释了......也是比较简单的结论 但是自己看到几何就退缩了...... 下周之内写一个计算几何的学习笔记! Code #include<iostream> #i ...
- [NOI.AC省选模拟赛3.31] 附耳而至 [平面图+最小割]
题面 传送门 思路 其实就是很明显的平面图模型. 不咕咕咕的平面图学习笔记 用最左转线求出对偶图的点,以及原图中每个边两侧的点是谁 建立网络流图: 源点连接至每一个对偶图点,权值为这个区域的光明能量 ...
随机推荐
- 846. Hand of Straights - LeetCode
Question 846. Hand of Straights Solution 题目大意:打牌,判断牌是否能全部按顺子出 思路:构造一个list,存储1,2,3,4,5,6,7,8并排序,构造一个m ...
- 好客租房42-react组件基础综合案例-渲染列表无数据并优化
渲染列表评论 1判断列表数据的长度是否为0 2如果为0 则渲染暂无评论 //导入react import React from 'react' import ReactDOM from 'react- ...
- [C++STL] vector 容器的入门
vector容器的入门 #include<vector> 创建vector容器的几种方式 数据类型可以是结构体,也能是另外一个容器 vector 的初始化: (1) 创建并声明大小 vec ...
- .NET MAUI 正式发布,再见了 Xamarin.Forms
David Ortinau 在dotnet 团队博客上发表了一篇文章<Introducing .NET MAUI – One Codebase, Many Platforms>,在这篇文章 ...
- css页面样式初始化
为什么? 同一个样式,在各个浏览器的默认样式可能不同,所以需要统一初始化,同一个页面在不同浏览器能正常显示. @charset "utf-8"; /*css reset*/ bod ...
- CF1580E Railway Construction
CF1580E Railway Construction 铁路系统中有 \(n\) 个车站和 \(m\) 条双向边,有边权,无重边.这些双向边使得任意两个车站互相可达. 你现在要加一些单向边 \((u ...
- C#/VB.NET 在PDF表格中添加条形码
条码的应用已深入生活和工作的方方面面.在处理条码时,常需要和各种文档格式相结合.当需要在文档中插入.编辑或者删除条码时,可借助于一些专业的类库工具来实现.本文,以操作PDF文件为例,介绍如何在编辑表格 ...
- 开发工具-Unix时间戳转换
更新日志 2022年6月10日 初始化链接. https://toolb.cn/timestamp
- 文件输入输出处理-File
大佬的理解-><IO流和File> 1.File类 File类是IO包中唯一代表磁盘文件本身的对象,File类定义了一些与平台无关的方法来操作文件.通过调用File类提供的各种方法, ...
- gnet: 一个轻量级且高性能的 Go 网络框架 使用笔记
一个偶然的机会接触到了golang,被它的高并发传说所吸引,就开始学这门语言,越学感觉越有意思^_^ 注册了博客园这么多年,第一次写东西,年纪大了,脑子不好使了,就得写下来,记下来,为了自己以后查阅, ...