其实就是数据结构课后题整理....只会一个是什么鬼

染色问题:

线段树? 功能太强大了! 我们并不需要那么多的功能

运用并查集!!!

将相同的并为一段

BZOJ 2375(讲真我没找到这个题在哪里...)

(其实是因为我没有权限号啦~现在知道了)

题目大概是这样的:

小t非常喜爱画画,但是他还是一个初学者.他最近费尽千辛万苦才拜到已仙逝的达.芬奇为师(神仙?妖怪?谢谢).

达.芬奇果然是画鸡蛋长大的,让小t一入门就拿着一张白纸条疯狂地涂色.

假设纸条被划分成了n个区域,用1~n的整数从左到右顺序编号,达芬奇总共下达了m条指令.

第I条指令是让小t把编号为(I*p+q)mod n+1与(I*q+p)mod n+1(p,q为常整数)之间的区域(连续的一段区域)涂成第I种颜色.

你可以假设达芬奇家中颜料的颜色数足够多(达芬奇是画鸡蛋长大的).

现在由于达芬奇下达的指令过多,小t一时应付不过来.达芬奇只让他回答每一个区域最后的颜色.
趁达芬奇还在“五谷轮回之所”忙碌时,小t偷偷的请让你这个计算机高手帮他算出最后的颜色状态,并告诉他.时间紧迫,要快哟!(达芬奇的指令次数多到恶心)是真的恶心

输入格式

文件仅一行,为四个整数n,m,p,q。

输出格式

文件共n行,第i行代表最后第i个格子的颜色。白色编号为0

输入样例

4 3 2 4(假样例....)

输出样例

2

2

3

0

数据范围

20%数据满足:1≤n≤1000,1≤m≤10000

40%数据满足:1≤n≤10000,1≤m≤100000

100%数据满足:1≤n≤1000000,1≤m≤10000000;1≤m*p+q,m*q+p≤231-1

/*思路+小技巧*/

因为一开始染好的色,如果后来也将其染色,那么他以前染过的颜色便会被覆盖,所以我们大可以不必从前往后进行染色可以考虑从后往前进行,

但是这样做所扫过的还是每个区间的长度,所以还需要进行优化!

那么怎么优化呢?

首先考虑bool数组,记录下来是否被染过色,如果染过就跳过,但是这样做还是全部都扫过一遍,在复杂度上是没有什么本质上的变化的

所以划掉

接下来我们需要考虑的是并查集的性质,以及考虑其父亲结点,……

正确的思路是这样的:

一开始先将父结点设置为自己(并查集~)

将被染色的结点的父亲结点都手动设置为该染色区间的最后一个的父结点,然后将接下来再次染色的循环从要被染色的结点的父亲结点开始。

因为没有染过色的结点的父亲结点一定是自己,但是染过色的的父亲结点却不是自己,是已经染色的区间的最后,会直接蹦到没有被染色的地方!

所以可以将for循环染色的开始设置为这个结点的父亲结点,限制条件是当前长度小于被染色区间的最右边(及当前被染色区间最后一个结点),下一个变成的是当前的结点的父亲的下一个结点的父结点,以此循环...

所以遇到这种题我们需要考虑的就是:尽量不重复刷,(因为只需要知道最后颜色状态).

代码如下(其他的就是并查集的操作):

for (int a=m;a>=;a--) //逆序
{
for (int b=getf(l[a]);b<=r[a];b=getf(b+)) //如上面的解释
{
if (!color[b]) //如果没有被染色
{
color[b]=;//标记
ans[b]=a;//记录答案
f[getf(b)]=getf(r[a]);//进行合并
}
}
}

完整代码:(已经经过检验=u=请放心食用)

 #include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <string> using namespace std; const int M = ;
int n,m,p,q;
int f[M];
bool color[M];
int ans[M]; inline int read()
{
int x=,f=;
char ch=getchar(); while(ch<''||ch>'')
{
if(ch=='-')f=-;
ch=getchar();
} while(ch>=''&&ch<='')
{
x=*x+ch-'';
ch=getchar();
} return x*f;
} inline int getf(int x)
{
return f[x] == x ? x : f[x] = getf(f[x]);
} int main()
{
n=read();
m=read();
p=read();
q=read();
for(int i=;i<=n+;i++) f[i]=i; //因为有可能会蹦到n+1位置
for(int i=m;i>=;i--)
{
int l=(i*p+q)%n+,r=(i*q+p)%n+; //题目的变态要求...
if(l>r) swap(l,r); //可能会出现"左端点">"右端点"的情况
for(int j=getf(l);j<=r;j=getf(j+))
{
if(!color[j]) //如果没有被染色
{
color[j]=; //进行染色
f[getf(j)]=getf(r); //将当前被染色的父结点手动设置到最后一个的父结点
// f[getf(j)]=getf(j+1); //在网上是有人这样写的,那样比较快一些!但是我没有理解...
ans[j]=i; //记录答案
}
// if(getf(1) == n+1) break; //注意当所有位置全部染色后及时退出
}
} for(int i=;i<=n;i++) printf("%d\n",ans[i]); return ;
}

^_^

End.

【説明する】DS的更多相关文章

  1. POJOの説明

    参考URL: https://baike.baidu.com/item/POJO/3311958?fr=aladdin https://wenku.baidu.com/view/eba89bbcf12 ...

  2. 【説明する】hash

    首先对于判重,我们能想到的方法有什么呢? 1)bool数组 2)set(集) 数组与集合的优缺点: 1.因为集合是对数组做的封装,所以,数组永远比任何一个集合要快. 2.数组声明了它容纳的元素的类型, ...

  3. 【説明する】KMP

    KMP是一个困扰我很久的算法,听老师或者是学姐讲了差不多有4次了,但是还是搞不太懂,今天终于,终于,终于搞懂了! ——2017-10-29 Vanora 首先推荐一下KMP详解——July 读罢之后内 ...

  4. 【説明する】STL

    作为C++标准不可缺少的一部分,STL应该是渗透在C++程序的角角落落里的. STL不是实验室里的宠儿,也不是程序员桌上的摆设,她的激动人心并非昙花一现. 所以今天要整理的东西就是STL!(orz 杨 ...

  5. winform导出excel

    public void AllDataSetToExcel(DataSet ds) { string saveFileName = ""; bool fileSaved = fal ...

  6. UbuntuでPostgreSQLをインストールからリモートアクセスまでの手順

    PostgreSQLサーバの立ち上げに少しハマりましたので.メモしておきます. OS: Ubuntu14.04 LTS インストール 最初はPostgreSQLをインストールします.普通にapt-ge ...

  7. VirtualBox 共享文件夾

    説明:host為window10,guest為centos7 一.安装VBoxLinuxAdditions 1. 在guest上挂载virtualbox安装目录下的VBoxGuestAdditions ...

  8. Ruby中字符串与正则表达式的问题

    Ruby的正则表达式为Regexp类的对象 主要的元语言字符 記号 意味 例 説明 ^ 行頭 /^abc/ abcで始まる行 $ 行末 /abc$/ abcで終わる行 . 任意の1文字 /a.b/ a ...

  9. WebMidiLink

    g200kg > WebMidiLink > 1.Introduction WebMidiLink 2012/06/26 1.Introduction « Prev 1.Introduct ...

随机推荐

  1. django框架ORM数据库

    字段类型 选项 null是数据库范畴的概念,blank是表单验证范畴的 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.mode ...

  2. TensorFlow学习笔记5-概率与信息论

    TensorFlow学习笔记5-概率与信息论 本笔记内容为"概率与信息论的基础知识".内容主要参考<Deep Learning>中文版. \(X\)表示训练集的设计矩阵 ...

  3. JMeter学习笔记16-如何输出HTML格式的性能测试报告

    文本来学习下,如何输入HTML格式的JMeter测试报告.前面已经介绍, 如果要做性能测试,需要在GUI上设计好你的Test Plan,设置各种场景和负载值,包括多少个线程,多少个用户,循环多少次.设 ...

  4. 从SVN下检出项目内容【步骤】

    1.新创建一个新的工作环境,然后new--->other--->SVN 2.点击Next,然后进行检出项目的操作,如下图所示: 3.再点击Next,进行输入指定的url地址,从指定的url ...

  5. [Luogu P3825] [NOI2017] 游戏 (2-SAT)

    [Luogu P3825] [NOI2017] 游戏 (2-SAT) 题面 题面较长,略 分析 看到这些约束,应该想到这是类似2-SAT的问题.但是x地图很麻烦,因为k-SAT问题在k>2的时候 ...

  6. Linux 重定向命令有哪些?有什么区别?

    1.重定向>Linux 允许将命令执行结果重定向到一个文件,本应显示在终端上的内容保存到指定文件中.如:ls >test.txt ( test.txt 如果不存在,则创建,存在则覆盖其内容 ...

  7. SCUT - 37 - 手速帝CZK - 分块

    https://scut.online/p/37 一开始想到要根号分块预处理,但是不太懂具体怎么写.想不到如此暴力. #include<bits/stdc++.h> using names ...

  8. 洛谷 - P3649 - 回文串 - 回文自动机

    https://www.luogu.org/problem/P3649 #include <bits/stdc++.h> using namespace std; typedef long ...

  9. 音频视频的播放的进度调整(以.net为例)

    Background:对于音视频在线播放,一些小应用是靠nginx处理访问视频.音频文件的请求,对外应用的一般会托管至各种云上使用相关的服务.前者存在巨大的安全隐患,后者会有一定的成本.有的时候还是需 ...

  10. MTCNN 人脸检测

    demo.py import cv2 from detection.mtcnn import MTCNN # 检测图片中的人脸 def test_image(imgpath): mtcnn = MTC ...