1483:[HNOI]2009 梦幻布丁 - BZOJ
Description
N个布丁摆成一行,进行M次操作.每次将某个颜色的布丁全部变成另一种颜色的,然后再询问当前一共有多少段颜色.例如颜色分别为1,2,2,1的四个布丁一共有3段颜色.
Input
第一行给出N,M表示布丁的个数和好友的操作次数. 第二行N个数A1,A2...An表示第i个布丁的颜色从第三行起有M行,对于每个操作,若第一个数字是1表示要对颜色进行改变,其后的两个整数X,Y表示将所有颜色为X的变为Y,X可能等于Y. 若第一个数字为2表示要进行询问当前有多少段颜色,这时你应该输出一个整数. 0
Output
针对第二类操作即询问,依次输出当前有多少段颜色.
Sample Input
4 3
1 2 2 1
2
1 2 1
2
Sample Output
3
1
把每种颜色的布丁做成一个链表,每次把两个链表合并,用启发式合并,时间均摊O(mlogn)
 我们算答案的时候是相邻的不同颜色就加1,所以我们先减去与X颜色有关的,即把ans减去X相邻的与X不同的有多少个
 把X变成Y以后再加上变成Y的相邻的与Y颜色不同的个数
var
head,sum,f:array[..]of longint;
next,c:array[..]of longint;
n,m,ans:longint; procedure swap(var x,y:longint);
var
t:longint;
begin
t:=x;
x:=y;
y:=t;
end; procedure init;
var
i:longint;
begin
read(n,m);
for i:= to do
f[i]:=i;
for i:= to n do
begin
read(c[i]);
inc(sum[c[i]]);
next[i]:=head[c[i]];
head[c[i]]:=i;
if c[i]<>c[i-] then inc(ans);
end;
end; procedure work;
var
i,q,k1,k2,j,k:longint;
begin
for i:= to m do
begin
read(q);
if q= then writeln(ans)
else
begin
read(k1,k2);
if f[k1]=f[k2] then continue;
if sum[f[k1]]>sum[f[k2]] then swap(f[k1],f[k2]);
k1:=f[k1];
k2:=f[k2];
if sum[k1]= then continue;
inc(sum[k2],sum[k1]);
sum[k1]:=;
j:=head[k1];
while j<> do
begin
if c[j]<>c[j-] then dec(ans);
if (j<n)and(c[j]<>c[j+]) then dec(ans);
j:=next[j];
end;
j:=head[k1];
while j<> do
begin
c[j]:=k2;
j:=next[j];
end;
j:=head[k1];
while j<> do
begin
if c[j]<>c[j-] then inc(ans);
if (j<n)and(c[j]<>c[j+]) then inc(ans);
if next[j]= then k:=j;
j:=next[j];
end;
swap(head[k1],head[k2]);
next[k]:=head[k1];
head[k1]:=;
end;
end;
end; begin
init;
work;
end.
1483:[HNOI]2009 梦幻布丁 - BZOJ的更多相关文章
- [BZOJ 1483][HNOI 2009]梦幻补丁(有序表启发式合并)
		
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1483 分析: 先将不同的颜色的出现位置从小到大用几条链表串起来,然后统计一下答案 对于 ...
 - 数据结构(启发式合并):HNOI 2009 梦幻布丁
		
Description N个布丁摆成一行,进行M次操作.每次将某个颜色的布丁全部变成另一种颜色的,然后再询问当前一共有多少段颜色.例如颜色分别为1,2,2,1的四个布丁一共有3段颜色. Input 第 ...
 - [HNOI 2009]梦幻布丁
		
Description 题库链接 维护一个序列 \(A\) .支持以下操作: \(X~Y\) 将序列中所有的 \(X\) 变成 \(Y\) : 询问序列颜色段数. \(1\leq n,m\leq 10 ...
 - BZOJ 1483:[HNOI2009]梦幻布丁(链表+启发式合并)
		
[HNOI2009]梦幻布丁 Description N个布丁摆成一行,进行M次操作.每次将某个颜色的布丁全部变成另一种颜色的,然后再询问当前一共有多少段颜色.例如颜色分别为1,2,2,1的四个布丁一 ...
 - BZOJ 1483:[HNOI2009]梦幻布丁(链表启发式合并)
		
http://www.lydsy.com/JudgeOnline/problem.php?id=1483 题意:中文. 思路:对于每一种颜色,用一个链表串起来,一开始保存一个答案,后面颜色替换的时候再 ...
 - 【BZOJ 1483】[HNOI2009]梦幻布丁
		
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 链表,启发式合并. 把x变成y,和y全都变成x. 不论是前者还是后者.连续段的个数都是相同的,不影响结果. 那么我们把x,y中出现次 ...
 - [BZOJ 1483] [HNOI2009] 梦幻布丁 (线段树合并)
		
[BZOJ 1483] [HNOI2009] 梦幻布丁 (线段树合并) 题面 N个布丁摆成一行,进行M次操作.每次将某个颜色的布丁全部变成另一种颜色的,然后再询问当前一共有多少段颜色.例如颜色分别为1 ...
 - bzoj 1483 [HNOI2009]梦幻布丁(链表+启发式合并)
		
1483: [HNOI2009]梦幻布丁 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1818 Solved: 761[Submit][Status ...
 - BZOJ 1483: [HNOI2009]梦幻布丁( 链表 + 启发式合并 )
		
把相同颜色的串成一个链表, 然后每次A操作就启发式合并, 然后计算对答案的影响. ----------------------------------------------------------- ...
 
随机推荐
- VS中的波浪线
			
绿色波浪线: 如果你的代码中出现了绿色的波浪线,说明你的代码语法并没有错误, 只不过提示你有可能会出现错误,但是不一定会出现错误.警告线 红色波浪线: 如果你的代码中出现了红色的波浪线,意味着你的代码 ...
 - DialogFragment
			
DialogFragment 从Android 3.0 (API level 11)开始引入,如果想在低于该版本的系统上使用,需用android.support.v4.app.DialogFragme ...
 - android组件间共享数据的常用方法
			
使用Intent在激活组件的时候携带数据,以进行数据的传递 使用广播进行组件间数据的伟递 使用外部存储(sharedPreference,文件,数据库,网络)进行组件间数据共享 使用Static静态成 ...
 - 使用TreeView+ListBox+TxtBox 资料管理器
			
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
 - Contoso 大学 - 10 - 高级 EF 应用场景
			
原文 Contoso 大学 - 10 - 高级 EF 应用场景 By Tom Dykstra, Tom Dykstra is a Senior Programming Writer on Micros ...
 - oracle视图索引
			
reate table fleet_header( day date,name varchar2(20), route_id number(5),fleet_id number(5)); crea ...
 - 第六篇、AVplayer定制视频播放控件
			
1.引用头文件#import AVFoundation 2.自定义AVPlayer(播放的机器) 3.自定义AVPlayerItem(胶片) >> 视频的URL转成AVAsset 4.AV ...
 - Quartz 第二课 Jobs and Triggers(官方文档翻译)
			
The Quartz API IScheduler—与scheduler交互的主要的接口 IJob—这个接口主要定义scheduler执行内容 IJobDetail—用于定义Jobs实例 ITrigg ...
 - jQuery学习教程(3)
			
一.什么是DOM操作? 文档对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口.在网页上,组织页面(或文档)的对象被组织在一个树形结 ...
 - ecshop中无限处理分类
			
数据库表记录结构 <?php $sql = "SELECT c.cat_id, c.cat_name, c.measure_unit, c.parent_id, c.is_show, ...