首先有一个暴力的做法,将任意两个点判断,可以得到与之相关的1或3只变色龙:1只是两只变色龙相互喜欢,那么剩下那只就是颜色相同;3只从3只选2只并和自己判断一次,结果为1的那次剩下的那个就是他喜欢的,然后将所有喜欢关系删掉后剩下的就是颜色相同
但这样一开始需要$o(n^2)$次的判断,考虑优化,如果将点划分成若干个集合,每一个集合内部没有特殊关系就可行了,然后就可以再集合中二分来查找了,那么直接对前i-1个点构成的图染成2种颜色(4种颜色容易超过次数),分别进行二分查找即可,次数是$o(nlogn)$的,常数要注意(4种颜色的要注意要取编号最小的颜色,不然会被卡)

 1 #include "chameleon.h"
2 #include <bits/stdc++.h>
3 using namespace std;
4 #define N 1005
5 vector<int>v,p[11],vec[N];
6 int vis[N],to[N],ans[N][2];
7 bool pd(vector<int> &k,int l,int r,int x){
8 p[4].clear();
9 p[4].push_back(x);
10 for(int i=l;i<=r;i++)p[4].push_back(k[i]);
11 return Query(p[4])<p[4].size();
12 }
13 void find(vector<int> &a,int l,int r,int i){
14 int rr=r;
15 while (1){
16 r=rr;
17 if ((vec[i].size()==3)||(!pd(a,l,r,i)))return;
18 while (l<r){
19 int mid=(l+r>>1);
20 if (pd(a,l,mid,i))r=mid;
21 else l=mid+1;
22 }
23 vec[i].push_back(a[l]);
24 vec[a[l]].push_back(i);
25 l++;
26 }
27 }
28 void Solve(int n){
29 n*=2;
30 for(int i=1;i<=n;i++){
31 int flag=4;
32 for(int j=0;j<4;j++)
33 if ((vec[i].size()==3)||(!pd(p[j],0,p[j].size()-1,i)))flag=min(flag,j);
34 else find(p[j],0,p[j].size()-1,i);
35 p[flag].push_back(i);
36 }
37 int t=0;
38 for(int i=1;i<=n;i++){
39 if (vec[i].size()<3)continue;
40 vis[i]=1;
41 for(int j=0;j<2;j++)
42 for(int k=j+1;k<3;k++){
43 v.clear();
44 v.push_back(i);
45 v.push_back(vec[i][j]);
46 v.push_back(vec[i][k]);
47 if (Query(v)==1){
48 to[i]=vec[i][3-j-k];
49 j=k=3;
50 }
51 }
52 if (!to[i])to[i]=vec[i][0];
53 }
54 for(int i=1;i<=n;i++)
55 if (vis[i]){
56 for(int j=0;j<3;j++)
57 if (vec[i][j]==to[i])vec[i][j]=0;
58 for(int j=0;j<3;j++)
59 if (vec[to[i]][j]==i)vec[to[i]][j]=0;
60 }
61 for(int i=1;i<=n;i++)
62 if (vis[i])
63 for(int j=0;j<3;j++)
64 if ((vec[i][j])&&(vec[i][j]<i)&&(vec[vec[i][j]].size()==3)){
65 ans[++t][0]=i;
66 ans[t][1]=vec[i][j];
67 }
68 for(int i=1;i<=n;i++)
69 if (vec[i].size()==1){
70 if ((vec[vec[i][0]].size()==1)&&(i>vec[i][0]))continue;
71 ans[++t][0]=i;
72 ans[t][1]=vec[i][0];
73 }
74 for(int i=1;i<=n/2;i++)Answer(ans[i][0],ans[i][1]);
75 }

[loj3274]变色龙之恋的更多相关文章

  1. JOISC2020 题解

    Day1T1 建筑装饰4 题目链接:Day1T1 建筑装饰4 Solution 我们先考虑朴素的\(dp\)方法: 设\(dp_{i,j,k}\)表示前\(i\)个数中,选了\(j\)个\(B\)数组 ...

  2. HP 820 G2变色龙安装10.11.6基本完美

    初始状态: 一块ssd硬盘,MBR格式分区,安装了WIN7 64位. 不想动win系统,因此就安装在硬盘的扩展分区 电脑配置: cpu: i7-5600u 声卡: ALC280 显卡: HD55 ...

  3. 变色龙安装程序 Chameleon Install 2.2 svn 2281发布

    变色龙安装程序 Chameleon Install 2.2 svn 2281发布 1.更好的支持10.9 Mavericks2.更新ATi.nVidia显卡支持列表3.添加新的 CPU Model I ...

  4. iATKOS v7硬盘安装教程(硬盘助手+变色龙安装版)

    这是作者:Tong 写的一篇安装教程 首先感谢:wowpc制作的变色龙安装版.iATKOS作者以及硬盘安装助手作者 前言:现在时代在进步,系统同样也在进步,在以前要在PC上整个Mac是很痛苦的事情,就 ...

  5. EasyBCD 2.2中文版安装变色龙wowpc.iso详细教程(适用各个版本)

    第一章 安装变色龙引导本章节提供3种安装方案,请自行选择 1.使用 Windows 版变色龙安装器安装适用引导方案:BIOS+MBR第1步:下载 Chameleon Install 2.2svn228 ...

  6. 纯windows下制作变色龙引导安装U盘教程

    原创教程:纯windows下制作变色龙引导安装U盘教程 支持Mavericks和Yosemite 支持白苹果 目标:windows下制作带 Chamelon变色龙引导的黑苹果安装U盘,支持PC机引导安 ...

  7. bzoj 3435: [Wc2014]紫荆花之恋 替罪羊树维护点分治 && AC400

    3435: [Wc2014]紫荆花之恋 Time Limit: 240 Sec  Memory Limit: 512 MBSubmit: 159  Solved: 40[Submit][Status] ...

  8. 轻奢当道业绩逆势增长 Kate Spade联手韩国衣恋开拓中国市场_商场报道_中国时尚品牌网

    轻奢当道业绩逆势增长 Kate Spade联手韩国衣恋开拓中国市场_商场报道_中国时尚品牌网 轻奢当道业绩逆势增长 Kate Spade联手韩国衣恋开拓中国市场

  9. Java之恋

    初次见面那是一个河北的夏天风随沙散落天涯蝴蝶依旧恋着花回首走过的日子手指和键盘之间的梦想之光已恍如昨日 那年我还是一个刚踏进这个曾经只在地理课本上狂念南稻北麦,南油北花的土地那年你只是我必须要学的编程 ...

随机推荐

  1. 洛谷4755 Beautiful Pair (分治)

    题目描述 小D有个数列 \(a\),当一个数对 \((i,j)(i\le j)\) 满足\(a_i\)和\(a_j\)的积 不大于 \(a_i \cdots a_j\) 中的最大值时,小D认为这个数对 ...

  2. 数据库DDL与DML对应含义

    DDL:指的是操作数据库.表.字段的相关语句,例如:create.alter.drop DML:指的是对表中的数据进行增删改的操作,例如:insert.update.delete 查询语句书写顺序:s ...

  3. Docker 常见命令

    Docker 运行流程 辅助命令 # 1.安装完成辅助命令 docker version -------------------------- 查看docker的信息 docker info ---- ...

  4. dubbo注册中心占位符无法解析问题

    dubbo注册中心占位符无法解析问题 1.背景 最近搞了2个老项目,想把他们融合到一起.这俩项目情况简介如下: 项目一:基于SpringMVC + dubbo,配置读取本地properties文件,少 ...

  5. 初学python-day3 元组

    day2 列表已更新!

  6. 【UE4 设计模式】观察者模式 Observer Pattern

    概述 描述 定义对象间的一种一对多依赖关系,使得每当一个对象状态发生改变时,其相关依赖对象皆得到通知并被自动更新.观察者模式又叫做 发布-订阅(Publish/Subscribe)模式 模型-视图(M ...

  7. 【数据结构与算法Python版学习笔记】算法分析

    什么是算法分析 算法是问题解决的通用的分步的指令的聚合 算法分析主要就是从计算资源的消耗的角度来评判和比较算法. 计算资源指标 存储空间或内存 执行时间 影响算法运行时间的其他因素 分为最好.最差和平 ...

  8. UltraSoft - DDL Killer - Alpha 项目展示

    团队介绍 CookieLau fmh 王 FUJI LZH DZ Monster PM & 后端 前端 前端 前端 后端 后端 软件介绍 项目简介 项目名称:DDLKiller 项目描述:&q ...

  9. OO课第三单元总结

    一.梳理JML语言的理论基础 (1)理论基础 JMl的出现很大程度上一为了行为接口的规范化,用这种语言来指定特定模块的特定功能.JML的核心部分分为三个部分:前置条件(requires).后置条件(e ...

  10. 2021.10.10考试总结[NOIP模拟73]

    T1 小L的疑惑 对于\(P_i\),如果所有比\(P_i\)小的数加起来也达不到\(P_i-1\),那么值域肯定不连续.否则设原来值域最大值为\(mx\),则\(P_i\)会让值域最大值增致\(mx ...