[计蒜客20191103C] 分组
小 C 是 \(n\) 个学生的老师,他现在要把所有学生分成两组,他会按照以下这些要求:
1、如果两个同学是好朋友那么他们就不会被分到同一组
2、小 C 想最小化两组人数差值
现在请你写一个程序来帮助小 C 分组,数据保证有合法的方案,如果有多种合法方案则输出字典序最小的
输入格式
第一行两个整数分别表示 \(n,m\)
接下来$ m$行,每行两个整数表示 \(x_i,y_i\)是好朋友
输出格式
如果第 \(i\) 位学生被分到第 1 组则第 \(i\) 位为 1,反之为 2
如果有多种合法方案则输出字典序最小的方案
数据范围
对于 \(30\%\) 的数据,\(2 \leq n \leq 16\)
对于 \(50\%\) 的数据,\(2 \leq n \leq 100\)
对于 \(100\%\) 的数据,\(2 \leq n \leq 1000,1 \leq m \leq 100000\)
输出时每行末尾的多余空格,不影响答案正确性
样例输入
6 4
1 2
1 3
4 6
4 5
样例输出
122211
如果把关系看成图论里的边,那么边相连的两个同学不能在一组,所以每一个连通块是一个二分图。就可以把一个连通块分成两部分学生,两部分学生一边是第一组,一边是第二组。
可以搜索考虑每一组的选择情况。把所有连通块按照最小编号的学生排完序后,为了让字典序尽量小,每个连通块优先让最小编号更小的那一部分选择1,其余选择2.过程中记录两组的差值。
发现搜索过程无后效性,记录\(dp_{i,j}\)为前i个连通块差值为\(j-N\)(防止负数)的情况是否枚举过。如果已经枚举过就不用再枚举一次了。复杂度O(n^2)
#include<bits/stdc++.h>
using namespace std;
const int N=1005;
int n,m,hd[N],t[N],idx=1,ans[N],v[N<<1][N<<1],k,ret=2e9,st[N],x,y;
struct edge{
int v,nxt;
}e[N<<8];
void add_edge(int u,int v,int z)
{
e[z]=(edge){v,hd[u]};
hd[u]=z;
}
vector<int>g[N+N];
void dfs(int x,int y)
{
t[x]=y,g[y].push_back(x);
for(int i=hd[x];i;i=e[i].nxt)
if(!t[e[i].v])
dfs(e[i].v,y^1);
}
void sou(int x,int y)
{
if(v[x][y+1000])
return;
if(x>idx)
{
if(abs(y)<ret)
memcpy(ans,st,sizeof(st)),ret=abs(y);
return;
}
v[x][y+1000]=1;
for(int i=0;i<g[x].size();i++)
st[g[x][i]]=1;
for(int i=0;i<g[x|1].size();i++)
st[g[x|1][i]]=2;
sou(x+2,y+g[x].size()-g[x|1].size());
for(int i=0;i<g[x].size();i++)
st[g[x][i]]=2;
for(int i=0;i<g[x|1].size();i++)
st[g[x|1][i]]=1;
sou(x+2,y+g[x|1].size()-g[x].size());
}
int main()
{
scanf("%d%d",&n,&m),k=n+n+1;
for(int i=1;i<=m;i++)
{
scanf("%d%d",&x,&y);
add_edge(y,x,i<<1);
add_edge(x,y,i<<1|1);
}
for(int i=1;i<=n;i++)
{
if(!t[i])
{
dfs(i,++idx);
++idx;
}
}
sou(2,0);
for(int i=1;i<=n;i++)
printf("%d",ans[i]);
}
[计蒜客20191103C] 分组的更多相关文章
- 计蒜客 作弊揭发者(string的应用)
鉴于我市拥堵的交通状况,市政交管部门经过听证决定在道路两侧安置自动停车收费系统.当车辆驶入车位,系统会通过配有的摄像头拍摄车辆画面,通过识别车牌上的数字.字母序列识别车牌,通过连接车管所车辆信息数据库 ...
- 计蒜客的一道题dfs
这是我无聊时在计蒜客发现的一道题. 题意: 蒜头君有一天闲来无事和小萌一起玩游戏,游戏的内容是这样的:他们不知道从哪里找到了N根不同长度的木棍, 看谁能猜出这些木棍一共能拼出多少个不同的不等边三角形. ...
- 计蒜客模拟赛5 D2T1 成绩统计
又到了一年一度的新生入学季了,清华和北大的计算机系同学都参加了同一场开学考试(因为两校兄弟情谊深厚嘛,来一场联考还是很正常的). 不幸的是,正当老师要统计大家的成绩时,世界上的所有计算机全部瘫痪了. ...
- 计蒜客 等边三角形 dfs
题目: https://www.jisuanke.com/course/2291/182238 思路: 1.dfs(int a,int b,int c,int index)//a,b,c三条边的边长, ...
- 计蒜客 方程的解数 dfs
题目: https://www.jisuanke.com/course/2291/182237 思路: 来自:https://blog.csdn.net/qq_29980371/article/det ...
- 计蒜客 买书 dfs
题目: https://www.jisuanke.com/course/2291/182236 思路: 递归解决,从第一本书开始,每本书都有两种选择: //index是book里面每本书价格的下标, ...
- 计蒜客:Entertainment Box
Ada, Bertrand and Charles often argue over which TV shows to watch, and to avoid some of their fight ...
- 爬虫acm比赛成绩(多页成绩整合在一起、获取复制不了的数据)(hihocoder、计蒜客)
https://github.com/congmingyige/web-crawler_rank-of-competition-in-JiSuanKe-and-hihocoder 1. 计蒜客(获取复 ...
- 计蒜客 31436 - 提高水平 - [状压DP]
题目链接:https://nanti.jisuanke.com/t/31436 作为一名车手,为了提高自身的姿势水平,平时的练习是必不可少的.小 J 每天的训练包含 $N$ 个训练项目,他会按照某个顺 ...
- 计蒜客 31434 - 广场车神 - [DP+前缀和]
题目链接:https://nanti.jisuanke.com/t/31434 小 D 是一位著名的车手,他热衷于在广场上飙车.每年儿童节过后,小 D 都会在广场上举行一场别样的车技大赛. 小 D 所 ...
随机推荐
- QA|如何实现一个函数读取1-9按钮?|网页计算器自动化测试实战
如何实现一个函数读取1-9按钮? 如何实现一个根据我们Json存的数字,自动选取对应按钮点击,并且点击对应算法? 首先我们肯定不能给每个元素都写一个函数吧,毕竟挺多,而且如果这样写了,那加减乘除都要分 ...
- strimzi实战之二:部署和消息功能初体验
欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 本篇概览 本篇是<strimzi实战>系列 ...
- 08-03_阅读flask上下文前夕补充、flask请求上下文、数据库连接池
文章目录 阅读flask上下文前夕补充 01 偏函数 02 __add__的使用 03 chain函数 2 flask请求上下文 1 首先分析请求上下文对象(ctx)创立 2 把请求对象(ctx)添加 ...
- 程序员必备:使用AI工具通义千问,没有广告没有假链接,比搜索引擎要便捷多了,回答还算满意
我提的问题是:使用Python连接Oracle,cx_Oracle和oracledb那个效率更高,功能更全,请列出他们的区别和实例代码 回复是: 以下是使用Python连接Oracle时,cx_Ora ...
- GPL协议原文及中文翻译
GPL协议原文及中文翻译 原文参考链接 翻译参考链接 原文 GNU GENERAL PUBLIC LICENSE Version 2, June 1991 Copyright (C) 1989, 19 ...
- Vue源码学习(十三):实现watch(一):方法,对象
好家伙, 代码出了点bug,暂时只能实现这两种形式 完整代码已开源https://github.com/Fattiger4399/analytic-vue.git Vue:watch的多种使用方法 ...
- K8S 组合命令
强制删除namespace kubectl get namespace [namespace-name] -o json | tr -d "\n" | sed "s/\& ...
- 全网最详细4W字Flink全面解析与实践(下)
本文已收录至GitHub,推荐阅读 Java随想录 微信公众号:Java随想录 原创不易,注重版权.转载请注明原作者和原文链接 承接上篇未完待续的话题,我们一起继续Flink的深入探讨 Flink S ...
- Centos7.5镜像获取
Centos.7.5镜像可从以下地址获取 镜像源地址:https://mirrors.tuna.tsinghua.edu.cn/ 1.下拉找到cc目录下的centos-vault 2.点击进入下一级目 ...
- JUC并发编程学习(十三)ForkJoin
ForkJoin 什么是ForkJoin ForkJoin在JDK1.7,并发执行任务!大数据量时提高效率. 大数据:Map Reduce(把大任务拆分成小任务) ForkJoin特点:工作窃取 为什 ...