NOI On Line 提高组题解
(话说其实我想填的是去年CSP的坑...但是貌似有一道题我还不会写咕咕咕...
先写一下这一次的题解吧.
T1:序列.题意省略。
两种操作。这种题要先分析部分分 给出了全部都是2操作的子任务。
发现A 2 B,B 2 C这个时候可以推到 A 2 C也就是所以被2相连的点都存在这种关系。
考虑缩点 把这些点都缩到一起表示他们的权值可以随便传递.
这个时候对于当前子任务我们可以很容易回答,就是看某个集合的权值和是否为0.
考虑有操作1的时候 A 1 B B 1 C 可以发现这可以转换成 A 2 C 转换成这样做之后我们再次把2操作进行缩点。
那么整张图变成了什么?对于1操作直接连边然后看能否缩点 2操作直接缩点 所以整张图变成了若干个联通块 且每个联通块至多只有两个点。
我们简单的分析一下什么时候有解,分类讨论一下即可。
值得一提的是对于1操作变2操作时我们连边需要拿2操作过后缩过的点连边,否则可能会出现(a,b) (c,d) 而c和d之前被缩起来了。
可以证明拿缩过点连边是正确的。(这个地方是坑点 考试的时候这个地方我就没考虑到。
```
const int MAXN=100010;
int n,m,cnt,flag,len,T;
int f[MAXN],vis[MAXN];ll a[MAXN];
int lin[MAXN],ver[MAXN我们很容易就可以得到一个非常暴力的模拟算法。
但是我们想要不去模拟就必须要知道每轮冒泡排序改变的是什么东西.
每一轮冒泡 整个序列中 未到位的最大值一定会交换到后面,这个时候考虑一下这个最大值所处的位置 如果为p的话,其应该到的位置为pos 那么说明p+1~pos这些数字对逆序对的贡献减一 (如果这个数字每次都在排头那么我们就可以不用知道序列是什么样子而直接求出来逆序对的变换情况了。
考虑这个最大值p之前的位置会怎么变换 可以发现还是一个较大值被交换到p+1这个位置然后轮到p开始交换。
至此我们不难发现每次冒泡某个数字之前如果有比其大的数字那么这种数字至少减少1.
设b[i]为i之前有多少个比i大的数字.那么进行k轮 每次每个位置上的b[i]都要减减.
答案=ans-$\sum{min(b[i],k)}$ans为初始序列的逆序对个数.这个显然可以利用线段树维护。
考虑修改 ans修改是O(1)的 b[i]的修改也仅限于一个位置 所以这是一个区间求和单点修改的问题.
树状数组好像需要两个才能维护 直接线段树即可.
```
const int MAXN=200010;
int n,m;
int a[MAXN],b[MAXN];
ll c[MAXN],ans;
inline int ask(int x)
{
int cnt=0;
while(x)
{
cnt+=c[x];
x-=x&(-x);
}
return cnt;
}
inline void add(int x,int y)
{
if(!x)return;
while(x>1;
build(pr)return;
if(l=t[p].r)
{
t[p].add+=k;
t[p].sum+=k*(t[p].r-t[p].l+1);
return;
}
spread(p);
long long mid=(t[p].l+t[p].r)>>1;
if(lmid)change(pr)return 0;
if(l=t[p].r)return t[p].sum;
spread(p);
long long mid=(t[p].l+t[p].r)>>1;
long long ans=0;
if(lmid)ans+=ask(pa[x+1])
{
change(1,b[x+1],b[x+1],-1);
--b[x+1];--ans;
swap(a[x],a[x+1]);
swap(b[x],b[x+1]);
}
else
{
change(1,b[x]+1,b[x]+1,1);
++b[x];++ans;
swap(a[x],a[x+1]);
swap(b[x],b[x+1]);
}
}
else
{
x=min(x,n);
ll w=ask(1,1,x);
printf("%lld\n",ans-w);
}
}
return 0;
}
```
ps:发现这个代码中的线段树长的不太好看了吧,这是很早以前的代码了,考试的时候为了节省时间直接粘了个板子.
T3:最小环.
当时写的时候时间不太够用了 因为T1debug时间过长。。
观察子任务有两个点k==1 简单分析一下什么时候形成的环最大 amax-4,amax-2,amax,amax-1,amax-3...这样排列。
这样计算可以发现能把样例算出来,关于证明:交换任意两个数的位置得到的结果不会比原来更优 所以这样排列就是最优的。
还有一个子任务n为偶数且k==2 我们发现此时形成了两个环。把n分一半套用上述k==1的做法即可解决。
对于$k\leq \frac{n}{2}$我们发现n和k互质的时候也只会形成一个环和k==1一样。
我们只需要知道对于一个k来说最终形成的环的个数有多少个 再把数分开单独计算每一个环即可。
可以发现形成环的个数为 gcd(n,k).
$n\leq 200000$ d(n)最多280..每次暴力计算每个环O(n) 所以总复杂度$d(n)\cdot n$.d(n)表示n的因子个数。
```
const ll MAXN=200010;
ll n,m;
ll a[MAXN],sum;
ll ans[MAXN];
inline ll cmp(ll a,ll b){return a>b;}
inline ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
int main()
{
//freopen("1.in","r",stdin);
//freopen("ring.out","w",stdout);
n=read();m=read();
for(ll i=1;i
NOI On Line 提高组题解的更多相关文章
- noip2010提高组题解
NOIP2010提高组题解 T1:机器翻译 题目大意:顺序输入n个数,有一个队列容量为m,遇到未出现元素入队,求入队次数. AC做法:直接开1000的队列模拟过程. T2:乌龟棋 题目大意:有长度为n ...
- NOIP 2014 提高组 题解
NOIP 2014 提高组 题解 No 1. 生活大爆炸版石头剪刀布 http://www.luogu.org/problem/show?pid=1328 这是道大水题,我都在想怎么会有人错了,没算法 ...
- NOIP 2001 提高组 题解
NOIP 2001 提高组 题解 No 1. 一元三次方程求解 https://vijos.org/p/1116 看见有人认真推导了求解公式,然后猥琐暴力过的同学们在一边偷笑~~~ 数据小 暴力枚举即 ...
- NOIP 2000 提高组 题解
NOIP2000 提高组 题解 No 1. 进制转换 https://www.rqnoj.cn/problem/295 水题 对于n和基数r, 每次用n mod r, 把余数按照逆序排列 注意 mod ...
- 【NOIP2018】提高组题解
[NOIP2018]提高组题解 其实就是把写过的打个包而已 道路铺设 货币系统 赛道修建 旅行 咕咕咕 咕咕咕
- luogu P6570 [NOI Online #3 提高组]优秀子序列 二进制 dp
LINK:P6570 [NOI Online #3 提高组]优秀子序列 Online 2的T3 容易很多 不过出于某种原因(时间不太够 浪了 导致我连暴力的正解都没写. 容易想到 f[i][j]表示前 ...
- [NOI Online 2021 提高组] 积木小赛
思路不说了. 想起来自己打比赛的时候,没睡好.随便写了个\(HASH\),模数开小一半分都没有. 然后学了\(SAM\),发现这个判重不就是个水题. \(SAM\)是字串tire的集合体. 随便\(d ...
- [NOI Online #2 提高组]涂色游戏 题解
题目描述 你有 1020 个格子,它们从 0 开始编号,初始时所有格子都还未染色,现在你按如下规则对它们染色: 编号是 p1 倍数的格子(包括 0号格子,下同)染成红色. 编号是 p2 倍数的格子染成 ...
- NOI Online 提高组 题解
来补坑了-- 个人认为三道题难度差不多-- 还有要说一嘴,为啥我在其他网站代码都好好的,复制到 cnblogs 上 Tab 就成 8 空格了?不过也懒得改了. T1 序列 首先,遇到这种加一减一还带附 ...
随机推荐
- nodejs gulp如何获取参数
比如执行gulp test 如果需要获取test,使用命令process.argv即可 如果执行gulp test --module aaaa,这句话表示的意思执行gulp test,顺带参数modu ...
- Milk Pumping
今天第一次正式打个人定位赛,还是太菜,这题连枚举加最短路都没想到,显然菜是原罪. 题面: : 题解:其实方法很多,千万别浪到网络流用dinic求最大网络流求的最小费用,这题不一样.最大流/最小费用 不 ...
- JAVA的8种基本数据类型分析
基本数据类型(8个) 1.整数类型(4个) 字节个数 取值范围 byte(字节) 1(8位) -2^7~2^7-1 short(短整型) 2(16位) -2^15~2^15-1 int(整形) 4 ...
- 从零开始学Electron笔记(一)
前端技术在最近几年迅猛发展,在任何开发领域我们都能看到前端的身影,从PC端到手机端,从APP到小程序,似乎前端已经无所不能,这就要求我们需要不断地去学习来提升自己!前段时间尤大通过直播介绍了一下Vue ...
- smtp 发送邮件实例
发送邮件的关键点在于邮箱服务器地址是否一致 //smtp 服务器地址,咨询 smtp 提供商,例如 smtp.126.net 这种格式,端口和服务器地址是配套的,一般是 465 或者 25 SmtpC ...
- java 面向对象(十九):关键字:static
static:静态的1.可以用来修饰的结构:主要用来修饰类的内部结构属性.方法.代码块.内部类2.static修饰属性:静态变量(或类变量) 2.1 属性,是否使用static修饰,又分为:静态属性 ...
- python 之 编码
本节内容 编码回顾 编码转换 Python的bytes类型 编码回顾 在备编码相关的课件时,在知乎上看到一段关于Python编码的回答 这哥们的这段话说的太对了,搞Python不把编码彻底搞明白,总有 ...
- jdk安装无反应解决方法
找到该文件(隐藏文件),如果里面是只有空格,清空后重新安装就可以.若有内容设置INSTALL_SILENT=0 后重新安装.
- 记录一次升级ant-design-vue的遇见的bug
记录一次升级ant-design-vue的遇见的bug 使用版本: "version": "2.5.2" "ant-design-vue": ...
- 【Nginx】面试官问我Nginx能不能配置WebSocket?我给他现场演示了一番!!
写在前面 当今互联网领域,不管是APP还是H5,不管是微信端还是小程序,只要是一款像样点的产品,为了增加用户的交互感和用户粘度,多多少少都会涉及到聊天功能.而对于Web端与H5来说,实现聊天最简单的就 ...