day1
t1的结论貌似在哪见过,自己稍微验证了一下貌似没记错就没有管了。
t2一道很好(keng)的模拟题啊
t3自己做题好慢啊,想出来dp打上去最后几分钟才过了大样例,我写的是记忆化搜索,判-1很好判,没时间加上去了可惜了,不过还是自己做题太慢了。然后由于没拍,不确定自己dp对不对,就特判了k=0粘了一个暴力,没想到暴力错了,70变成50...基础不扎实gg

100+100+50=250  好菜啊t3没A掉

day2
t1看完题就开始打,没注意算距离时减一下就变成两倍了会爆long long,但好像数据中z都>=0 ??
t2写完搜索后发现好像可以把所有点深度变成一个n进制数,可以记忆化,不过打完发现n=12要跑10s+,果断删掉换成爆搜。并没有想到如何状压...
t3打完前50分后有一个想法,打完后发现自己想的是错的,于是老老实实写x=1的30分,但耗费了好多时间,没时间打出个数据结构了,于是用了vector,还以为vector有多快,CCF的老爷机上1e5都跑不过,于是t3就挂了,暴力分都没拿全。

100+70+50=220 太菜了...

自己做较难题不行,另外noip中还犯了很多知识性错误,主要原因是学的不扎实,接下来的比赛加油吧。

题解

day1

t1 答案就是x*y-x-y,证明可以见usaco4.1麦香牛块的题解。貌似此题坑到了我校不少选手。

t2 细心模拟即可。

t3 设f(i,j)表示到i点从1~i距离为dis[i]+j的路径个数。对于边u->v,有dis[v]+jv=dis[u]+ju+w(u,v),所以$f(v,j_v)=\sum_{u->v}f(u,dis[v]-dis[u]-w(u,v)-j_v)$,具体实现可以建出反图记忆化搜索,答案为-1当且仅当同一状态在dfs栈中出现了两次。

day2

t1 建图后bfs判联通。

t2 f1(i,s)表示点i到集合s中点的最小权值,这个可以O(n^2*2^n)处理出。 f2(s1,s2)表示集合s2与s1相连花费的最小代价,O(n*3^n)处理。

f(i,s)表示已经确定了深度<=i的点,且这些点的集合为s,将来要付出的最小代价,枚举下一层选哪些点,f(i,s)=min{ f(i+1,s|s')+f2(s,s') },虽然s‘可能会连向深度<i的点,但如果这样转移了答案会变大,而且如果真要这样连,之前就会转移了的,所以不会计算出错的答案也不会漏掉最优解,这一部分复杂度是O(n*3^n)的。

t3 x=1可以用线段树完成,只需记当前区间未被删除的点的个数,删除第k个数直接查到删去即可,插入同理。

对于一般情况可以对每一排的前m-1个元素建出线段树,然后对最后一列再建出线段树,操作和x=1是一样的,但发现空间开不下,因为这n+1棵线段树最开始叶子节点是等差数列,所以动态开点即可。

附d2t3代码(巨难看)

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<vector>
#include<cmath>
#define P puts("lala")
#define cp cerr<<"lala"<<endl
#define pb push_back
#define fi first
#define se second
#define mkp make_pair
#define ln putchar('\n')
using namespace std;
typedef pair<int,int> pii;
inline void read(int &re)
{
char ch=getchar();int g=1;
while(ch<'0'||ch>'9') {if(ch=='-')g=-1;ch=getchar();}
re=0;
while(ch<='9'&&ch>='0') re=(re<<1)+(re<<3)+ch-48,ch=getchar();
re*=g;
}
typedef long long ll;
inline void read(ll &re)
{
char ch=getchar();ll g=1;
while(ch<'0'||ch>'9') {if(ch=='-')g=-1;ch=getchar();}
re=0;
while(ch<='9'&&ch>='0') re=(re<<1)+(re<<3)+ch-48,ch=getchar();
re*=g;
} const int N=300050;
int n,m,q;
int rt[N],ch[N*80][2],siz[N*80],sz=0;
ll val[N*80]; ll kth_las(int o,int l,int r,int k)
{
if(l==r) {return val[o];}
int mid=l+r>>1;
if(!ch[o][0])
{
ch[o][0]=++sz;ch[o][1]=++sz;
siz[ch[o][0]]=(siz[o]+1)>>1; siz[ch[o][1]]=siz[o]>>1;
if(l==mid) val[ch[o][0]]=(ll)l*m;
if(mid+1==r) val[ch[o][1]]=(ll)r*m;
}
if(k<=siz[ch[o][0]]) return kth_las(ch[o][0],l,mid,k);
else return kth_las(ch[o][1],mid+1,r,k-siz[ch[o][0]]);
} ll kth(int o,int l,int r,int k,int wh)
{
if(l==r) {return val[o];}
int mid=l+r>>1;
if(!ch[o][0])
{
ch[o][0]=++sz;ch[o][1]=++sz;
siz[ch[o][0]]=(siz[o]+1)>>1; siz[ch[o][1]]=siz[o]>>1;
if(l==mid) val[ch[o][0]]=(ll)(wh-1ll)*m+l;
if(mid+1==r) val[ch[o][1]]=(ll)(wh-1ll)*m+r;
}
if(k<=siz[ch[o][0]]) return kth(ch[o][0],l,mid,k,wh);
else return kth(ch[o][1],mid+1,r,k-siz[ch[o][0]],wh);
} void del(int o,int l,int r,int k)
{
if(l==r) {siz[o]=0;val[o]=0;return ;}
int mid=l+r>>1;
if(k<=siz[ch[o][0]]) del(ch[o][0],l,mid,k);
else del(ch[o][1],mid+1,r,k-siz[ch[o][0]]);
siz[o]=siz[ch[o][0]]+siz[ch[o][1]];
} void ins_las(int o,int l,int r,int x,ll k)
{
if(l==r) {siz[o]=1;val[o]=k;return ;}
int mid=l+r>>1;
if(!ch[o][0])
{
ch[o][0]=++sz;ch[o][1]=++sz;
siz[ch[o][0]]=(siz[o]+1)>>1; siz[ch[o][1]]=siz[o]>>1;
if(l==mid) val[ch[o][0]]=(ll)l*m;
if(mid+1==r) val[ch[o][1]]=(ll)r*m;
}
if(x<=siz[ch[o][0]]) ins_las(ch[o][0],l,mid,x,k);
else ins_las(ch[o][1],mid+1,r,x-siz[ch[o][0]],k);
siz[o]=siz[ch[o][0]]+siz[ch[o][1]];
} void ins(int o,int l,int r,int x,ll k,int wh)
{
if(l==r) {siz[o]=1;val[o]=k;return ;}
int mid=l+r>>1;
if(!ch[o][0])
{
ch[o][0]=++sz;ch[o][1]=++sz;
siz[ch[o][0]]=(siz[o]+1)>>1; siz[ch[o][1]]=siz[o]>>1;
if(l==mid) val[ch[o][0]]=(ll)(wh-1ll)*m+l;
if(mid+1==r) val[ch[o][1]]=(ll)(wh-1ll)*m+r;
}
if(x<=siz[ch[o][0]]) ins(ch[o][0],l,mid,x,k,wh);
else ins(ch[o][1],mid+1,r,x-siz[ch[o][0]],k,wh);
siz[o]=siz[ch[o][0]]+siz[ch[o][1]];
} void wj()
{
freopen("phalanx.in","r",stdin);
freopen("phalanx.out","w",stdout);
}
int main()
{
wj();
int i,j,opt,T;
read(n);read(m);read(q);
for(i=1;i<=n;++i)
{
rt[i]=++sz;siz[rt[i]]=m-1+q;
ch[rt[i]][0]=++sz; ch[rt[i]][1]=++sz;
siz[ch[rt[i]][0]]=(siz[rt[i]]+1)>>1; siz[ch[rt[i]][1]]=siz[rt[i]]>>1;
} rt[n+1]=++sz;siz[rt[n+1]]=n+q;
ch[rt[n+1]][0]=++sz; ch[rt[n+1]][1]=++sz;
siz[ch[rt[n+1]][0]]=(siz[rt[n+1]]+1)>>1; siz[ch[rt[n+1]][1]]=siz[rt[n+1]]>>1; for(int cas=1;cas<=q;++cas)
{
int x,y;read(x);read(y);
if(y==m)
{
ll o=kth_las(rt[n+1],1,n+q,x);
del(rt[n+1],1,n+q,x);
printf("%lld\n",o);
ins_las(rt[n+1],1,n+q,n,o);
}
else
{
ll o=kth(rt[x],1,m-1+q,y,x);
del(rt[x],1,m-1+q,y);
printf("%lld\n",o);//get (x,y) ll las=kth_las(rt[n+1],1,n+q,x);//get the last element and push it to the xth row
ins(rt[x],1,m-1+q,m-1,las,x); del(rt[n+1],1,n+q,x);//push o to the last column
ins_las(rt[n+1],1,n+q,n,o);
}
}
return 0;
}

NOIP2017总结 & 题解的更多相关文章

  1. NOIP2017 列队 题解报告【56行线段树】

    题目描述 Sylvia 是一个热爱学习的女♂孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia 所在的方阵中有n \times mn×m名学生,方阵的行数 ...

  2. NOIP2017 宝藏 题解报告【状压dp】

    题目描述 参与考古挖掘的小明得到了一份藏宝图,藏宝图上标出了 n 个深埋在地下的宝藏屋, 也给出了这 n 个宝藏屋之间可供开发的 m 条道路和它们的长度. 小明决心亲自前往挖掘所有宝藏屋中的宝藏.但是 ...

  3. [NOIp2017]宝藏 题解

    非常巧妙的 \(O(n^23^n)\) 做法. 题目的本质是要求一棵生成树,使得其每条边的长度与这条边的起点深度乘积的和最小. 我们使用状压 DP,考虑到当前状态与已经打通的点和深度有关,不妨设 \( ...

  4. noip2017普及题解

    https://www.luogu.org/problemnew/show/3954 https://www.luogu.org/problemnew/show/3955 https://www.lu ...

  5. NOIP2017 D2T3 题解

    题面 这种数据范围不是乱搞dfs就是乱搞状压DP 首先应该通过任一方式求出a和b的值: 任意一条抛物线只用两头猪就可以确定,所以我们N^2枚举,并把在这两头猪的抛物线上的猪都存进状态state[i][ ...

  6. noip2017简要题解。

    重新写了一下去年的题来看看自己到底是有多傻逼. 小凯的疑惑 打表. 时间复杂度 搞了一大坨题面,但是真正有用的信息只有几个: 判断他给你的复杂度是多少. 判断当前循环进不进的去. 判断当前循环产生的贡 ...

  7. Noip2018退役记。

    下面是边考试边写的严肃版退役记\(:D\) Day0 其实我本来想取个这个名字:\(NOIP2018\)提高组复赛试题解析 但是这个博客自己求生欲望太强自己改名了. 先占个坑. noip考前毒奶 \( ...

  8. 【NOIP题解】NOIP2017 TG D2T3 列队

    列队,NOIP2017 TG D2T3. 树状数组经典题. 题目链接:洛谷. 题意: Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. ...

  9. noip2017爆炸记——题解&总结&反省(普及组+提高组)

    相关链接: noip2018总结 noip2017是我见过的有史以来最坑爹的一场考试了. 今年北京市考点有一个是我们学校,我还恰好被分到了自己学校(还是自己天天上课的那个教室),于是我同时报了普及提高 ...

随机推荐

  1. Blazor和Vue对比学习(进阶2.2.3):状态管理之状态共享,Blazor的依赖注入和第三方库Fluxor

    Blazor没有提供状态共享的方案,虽然依赖注入可以实现一个全局对象,这个对象可以拥有状态.计算属性.方法等特征,但并不具备响应式.比如,组件A和组件B,都注入了这个全局对象,并引用了全局对象上的数据 ...

  2. 手搓一个“七夕限定”,用3D Engine 5分钟实现烟花绽放效果

    七夕来咯!又到了给重要的人送惊喜的时刻. 今年,除了将心意融入花和礼物,作为程序员,用自己的代码本事手搓一个技术感十足"七夕限定"惊喜,我觉得,这是不亚于车马慢时代手写信的古典主义 ...

  3. 8. 利用Ansible快速构建MGR | 深入浅出MGR

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 目录 1. 安装ansbile 2. 配置ansible 3. 建立ssh信任 4. 测试ansible 5. 使用ans ...

  4. JAVA语言基础组成(2)

    函数  函数的定义 1.什么是函数? 函数就是定义在类中的具有特定功能的一段独立小程序.函数也称为方法. 2.函数的格式: 修饰符 返回值类型 函数名(参数类型 形式参数1,参数类型 形式参数2,.. ...

  5. Dynamic CRM一对多关系的数据删除时设置自动删除关联的数据

    在业务实体中主子表非常常见,然后子表可能有会有自己的子表或者多对多关系,在删除的业务场景下,删除主数据,剩余的子数据就成了脏数据, 之前的做法是,监听主表的删除事件,然后在插件中找到其下的子表数据然后 ...

  6. 想学渗透测试,应该考CISP-PTE还是NISP-PT?|网安伴nisp和cisp

    其实两者都可,但要看考生的实际需求! 为什么说两者都可以? 两个证书都由中国信息安全测评中心颁发,CISP-PTE全称国家注册渗透测试工程师,NISP-PT全称国家信息安全水平考试-渗透测试工程师专项 ...

  7. 简单创建一个SpringCloud2021.0.3项目(四)

    目录 1. 项目说明 1. 版本 2. 用到组件 3. 功能 2. 上三篇教程 3. 日志处理 1. 创建日志公共模块 2. Eureka引入日志模块 4. 到此的功能代码 5. 注册中心换成naco ...

  8. 7个自定义定时任务并发送消息至邮箱或企业微信案例(crontab和at)

    前言 更好熟悉掌握at.crontab定时自定义任务用法. 实验at.crontab定时自定义任务运用场景案例. 作业.笔记需要. 定时计划任务相关命令及配置文件简要说明 at 工具 由包 at 提供 ...

  9. mydodo协议

    mydodo协议 目录 数据帧结构 命令 协议 代码样例 数据帧结构 帧头1 帧头2 设备号 命令 数据长度 数据 0x4D 0x59 xxx cmd nByte data 例子:设备my01 的继电 ...

  10. [LeetCode]-217.存在重复元素-简单

    217. 存在重复元素 给定一个整数数组,判断是否存在重复元素. 如果存在一值在数组中出现至少两次,函数返回 true .如果数组中每个元素都不相同,则返回 false . 示例 1: 输入: [1, ...