首先有一个暴力的做法,将任意两个点判断,可以得到与之相关的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. Linux基本命令 和 Regex 正则表达式

    Linux基本命令 和 Regex 正则表达式 Regex 基本语法 常用匹配规则 [aeiouAEIOU] # 从中随机选择一个 [0-9]{4} # 从中选择4个 .* # 匹配任意字符 \w # ...

  2. FastAPI 学习之路(十三)Cookie 参数,Header参数

    系列文章: FastAPI 学习之路(一)fastapi--高性能web开发框架 FastAPI 学习之路(二) FastAPI 学习之路(三) FastAPI 学习之路(四) FastAPI 学习之 ...

  3. 【UE4】GAMES101 图形学作业3:Blinn-Phong 模型与着色

    总览 在这次编程任务中,我们会进一步模拟现代图形技术.我们在代码中添加了Object Loader(用于加载三维模型), Vertex Shader 与Fragment Shader,并且支持了纹理映 ...

  4. Android构建工具--AAPT2源码解析(一)

    一.什么是AAPT2 在Android开发过程中,我们通过Gradle命令,启动一个构建任务,最终会生成构建产物"APK"文件.常规APK的构建流程如下: (引用自Google官方 ...

  5. 痞子衡嵌入式:超级下载算法RT-UFL v1.0在Keil MDK下的使用

    痞子衡主导的"学术"项目 <RT-UFL - 一个适用全平台i.MXRT的超级下载算法设计> v1.0 版发布近 4 个月了,部分客户已经在实际项目开发调试中用上了这个 ...

  6. K8s容器存储接口(CSI)介绍

    Container Storage Interface是由来自Kubernetes.Mesos.Docker等社区member联合制定的一个行业标准接口规范,旨在将任意存储系统暴露给容器化应用程序. ...

  7. Linux服务器装Anaconda&TensorFlow

    远程Linux服务器装Anaconda&指定版本TensorFlow 说明: 由于疫情影响,原先使用的服务器已断电,故重选了一台服务器对环境重选进行搭建,正好补上这篇博文. 01 下载Anac ...

  8. js模板引擎laytpl的使用

    在我们实际的开发过程中,可能会遇到使用ajax去后台获取一堆的数据,然后动态的渲染到页面上.比如:去后台获取一个list集合,然后将数据以表格的形式展示在页面上.另外一种可能发生的情况就是页面上需要批 ...

  9. VS2019、Qt5.12及QGis3.16开发常见问题汇总

    在C++.Qt软件开发过程中,常常遇到一些编译错误或警告:本文将VS2019.Qt5.12.10和QGis3.16.10的二次开发过程常见的问题做了整理,供大家参考,也便于日后查阅.该内容分为四部分: ...

  10. qgis cookbook-QgsMapRendererJob学习

    学习到渲染(QgsMapRendererJob),按照教程所讲总是输出不了图像,看了一下qgis的测试源码,发现少了一句话,加上后就可以输出了! from qgis.core import * fro ...