[cf1240F]Football
(事实上,总是可以让每一场都比,因此$w_{i}$并没有意义)
当$k=2$时,有如下做法——
新建一个点,向所有奇度数的点连边,并对得到的图求欧拉回路,那么只需要将欧拉回路上的边交替染色,即可保证$|s_{i,1}-s_{i,2}|\le 1$(路径长度为奇数时的起点),去掉新建的点后仍有$|s_{i,1}-s_{i,2}|\le 2$,也即合法
当$k$任意时,有如下做法——
随机一组方案,找到两种不合法的颜色$a$和$b$(即$\exists i,|s_{i,a}-s_{i,b}|\ge 3$),将图中颜色为$a$或$b$的边用$k=2$时的方式重新染色,重复此过程直至找到不到$a$和$b$,显然此时即合法
考虑这一做法的复杂度(和有限性),令$C=\sum_{i=1}^{n}\sum_{j=1}^{k}s_{i,j}^{2}$,考虑调整对$C$的影响:假设调整后的为$s'_{i,j}$,代入该式即使得$C$减少$\sum_{i=1}^{n}(s_{i,a}^{2}+s_{i,b}^{2}-s{'}_{i,a}^{2}-s{'}_{i,b}^{2})$
由于$s_{i,a}+s_{i,b}$固定,因此$|s'_{i,a}-s'_{i,b}|\le 1$时必然取到最小,即每一项该值均非负
另一方面,对于$|s_{i,a}-s_{i,b}|\ge 3$的位置,该值至少为4,也即$C$至少减少4
同时$C$非负,因此轮数为$o(C)$,其实际意义可以看作选择两条边满足有公共点且颜色相同,那么先确定其中一条边,由于没有重边,显然另一条边至多有$o(n)$种,即$C\le nm$
另外,每一轮调整复杂度为$o(n\log k+m)$(找$x,y$和求欧拉回路)
时间复杂度为$o(n^{2}m\log k+nm^{2})$,由于跑不满,可以通过

1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 105
4 #define M 1005
5 #define fi first
6 #define se second
7 struct Edge{
8 int nex,to;
9 }edge[N+M<<1];
10 pair<int,int>e[M];
11 multiset<int>S[N];
12 int n,m,t,E,P,head[N],vis[N+M],ans[M],sum[N][M];
13 void add(int x,int y){
14 edge[E].nex=head[x];
15 edge[E].to=y;
16 head[x]=E++;
17 }
18 void dfs(int k){
19 for(int i=head[k];i!=-1;i=edge[i].nex)
20 if (vis[i>>1]<0){
21 vis[i>>1]=0;
22 dfs(edge[i].to);
23 vis[i>>1]=P,P^=1;
24 }
25 }
26 int main(){
27 srand(time(0));
28 scanf("%d%d%d",&n,&m,&t);
29 for(int i=1;i<=n;i++)scanf("%*d");
30 for(int i=1;i<=m;i++)scanf("%d%d",&e[i].fi,&e[i].se);
31 for(int i=1;i<=m;i++){
32 ans[i]=rand()%t+1;
33 sum[e[i].fi][ans[i]]++;
34 sum[e[i].se][ans[i]]++;
35 }
36 for(int i=1;i<=n;i++)
37 for(int j=1;j<=t;j++)S[i].insert(sum[i][j]);
38 while (1){
39 int x=0,y=0;
40 for(int i=1;i<=n;i++)
41 if ((*--S[i].end())-(*S[i].begin())>=3){
42 x=y=1;
43 for(int j=2;j<=t;j++){
44 if (sum[i][j]>sum[i][x])x=j;
45 if (sum[i][j]<sum[i][y])y=j;
46 }
47 break;
48 }
49 if ((!x)&&(!y))break;
50 E=P=0;
51 memset(head,-1,sizeof(head));
52 for(int i=1;i<=m;i++)
53 if ((ans[i]==x)||(ans[i]==y)){
54 add(e[i].fi,e[i].se);
55 add(e[i].se,e[i].fi);
56 }
57 for(int i=1;i<=n;i++)
58 if ((sum[i][x]+sum[i][y])&1)add(0,i),add(i,0);
59 memset(vis,-1,sizeof(vis));
60 for(int i=1;i<=n;i++)dfs(i);
61 for(int i=1;i<=n;i++){
62 S[i].erase(S[i].find(sum[i][x]));
63 S[i].erase(S[i].find(sum[i][y]));
64 sum[i][x]=sum[i][y]=0;
65 }
66 for(int i=1,j=0;i<=m;i++)
67 if ((ans[i]==x)||(ans[i]==y)){
68 if (vis[j])ans[i]=x;
69 else ans[i]=y;
70 sum[e[i].fi][ans[i]]++;
71 sum[e[i].se][ans[i]]++;
72 j++;
73 }
74 for(int i=1;i<=n;i++){
75 S[i].insert(sum[i][x]);
76 S[i].insert(sum[i][y]);
77 }
78 }
79 for(int i=1;i<=m;i++)printf("%d\n",ans[i]);
80 return 0;
81 }
[cf1240F]Football的更多相关文章
- POJ 3071 Football
很久以前就见过的...最基本的概率DP...除法配合位运算可以很容易的判断下一场要和谁比. from——Dinic算法 Football Time ...
- Football Foundation (FOFO) TOJ 2556
The football foundation (FOFO) has been researching on soccer; they created a set of sensors to desc ...
- 17111 Football team
时间限制:1000MS 内存限制:65535K 提交次数:0 通过次数:0 题型: 编程题 语言: C++;C Description As every one known, a footbal ...
- CodeForces 432B Football Kit
Football Kit Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Subm ...
- Football(POJ3071)
Football Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3469 Accepted: 1782 Descript ...
- 16年大连网络赛 1006 Football Games
题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?cid=725&pid=1006 Football Games Time ...
- 三分--Football Goal(面积最大)
B - Football Goal Time Limit:500MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Su ...
- HDU5873:Football Games
题目链接: Football Games 分析: 先将分数排序,然后 设当前队编号为p,设个指针为p+1,然后p>1,每次p-=2,指针右移一位p==1,指针指向的队-=1p==0,从指针开始到 ...
- Codeforces Gym 100425H H - Football Bets 构造
H - Football BetsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/ ...
随机推荐
- mysql从零开始之MySQL DELETE 语句
MySQL DELETE 语句 你可以使用 SQL 的 DELETE FROM 命令来删除 MySQL 数据表中的记录. 你可以在 mysql> 命令提示符或 PHP 脚本中执行该命令. 语法 ...
- Linux Bash命令杂记(cut sort uniq wc tee)
Linux Bash命令杂记(cut sort uniq wc tee) 数据流重定向 标准输入(stdin):代码为0,使用<或<<: 标准输出(stdout):代码为1,使用&g ...
- python 注册 gin consul
import requests headers = { "contentType": "application/json" } def register(nam ...
- Python基础 | 字符串格式化输出及print()函数介绍
在写代码时,我们会经常与字符串打交道,Python中控制字符串格式通常有三种形式,分别是使用str%,str.format(),f-str,用法都差不多,但又有一些细微之差. 一起来看看吧~~~ 一. ...
- 一次OutOfMemoryError: GC overhead limit exceeded
现象: 由于需要将mysql表中的过期数据在凌晨定时读取出过滤后转入到MongoDB,一个转换SQL达到百行,而且有几十个,集中运行后程序反馈异常: Handler dispatch failed; ...
- Java初步学习——2021.10.05每日总结,第五周周三
(1)今天做了什么: (2)明天准备做什么? (3)遇到的问题,如何解决? 今天学了对象与类,如何定义类和创建对象,以及构建方法的用法. 明天课比较多,把今天未学的例子敲一遍好了. 没有遇到什么问题.
- Spring的JDK动态代理如何实现的(源码解析)
前言 上一篇文章中提到了SpringAOP是如何决断使用哪种动态代理方式的,本文接上文讲解SpringAOP的JDK动态代理是如何实现的.SpringAOP的实现其实也是使用了Proxy和Invoca ...
- Go语言核心36讲(Go语言进阶技术三)--学习笔记
09 | 字典的操作和约束 至今为止,我们讲过的集合类的高级数据类型都属于针对单一元素的容器. 它们或用连续存储,或用互存指针的方式收纳元素,这里的每个元素都代表了一个从属某一类型的独立值. 我们今天 ...
- Less-32 宽字节
<!-- 下午整了半天Less-29~31,愣是没调好jsp环境,只好跳过. 难受.jpg !--> Less-32: 核心语句: 各种回显均存在. 第一句话指定了字符集为gbk. che ...
- 【UE4】GAMES101 图形学作业0:矩阵初识
作业描述 给定一个点P=(2,1), 将该点绕原点先逆时针旋转45◦,再平移(1,2), 计算出变换后点的坐标(要求用齐次坐标进行计算). UE4 知识点 主要矩阵 FMatrix FBasisVec ...