(事实上,总是可以让每一场都比,因此$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的更多相关文章

  1. POJ 3071 Football

    很久以前就见过的...最基本的概率DP...除法配合位运算可以很容易的判断下一场要和谁比.    from——Dinic算法                         Football Time ...

  2. Football Foundation (FOFO) TOJ 2556

    The football foundation (FOFO) has been researching on soccer; they created a set of sensors to desc ...

  3. 17111 Football team

    时间限制:1000MS  内存限制:65535K 提交次数:0 通过次数:0 题型: 编程题   语言: C++;C Description As every one known, a footbal ...

  4. CodeForces 432B Football Kit

     Football Kit Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Subm ...

  5. Football(POJ3071)

    Football Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3469   Accepted: 1782 Descript ...

  6. 16年大连网络赛 1006 Football Games

    题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?cid=725&pid=1006 Football Games Time ...

  7. 三分--Football Goal(面积最大)

    B - Football Goal Time Limit:500MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Su ...

  8. HDU5873:Football Games

    题目链接: Football Games 分析: 先将分数排序,然后 设当前队编号为p,设个指针为p+1,然后p>1,每次p-=2,指针右移一位p==1,指针指向的队-=1p==0,从指针开始到 ...

  9. Codeforces Gym 100425H H - Football Bets 构造

    H - Football BetsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/ ...

随机推荐

  1. 【.Net vs Java? 】 先来看一下Java和C#的数据类型区别。

    新工作.Net和Java都要做,早期也做过一段Java的项目,但没有系统的深入学习过.一直觉得这两门语言估计是最相近的两门语言了,好多代码可以说直接拷过来都不带报错的,但仔细推敲还是有很多的不同. 1 ...

  2. mysql中一半会选择什么样的字段为索引?(含索引创建删除查看公式)

    一.数据量庞大的数据做索引 二.该字段经常出现在where的后面,以条件形式存在,经常被用户搜索的字段 三.很少被增删改的字段,因为增删改后,索引会重新排序 索引的创建 create index 索引 ...

  3. torch.nn.Sequential()详解

    参考:官方文档    源码 官方文档 nn.Sequential A sequential container. Modules will be added to it in the order th ...

  4. Mybatis初始化机制

    对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外.本章将通过以下几点详细介绍MyBatis的初始化过程. 1.MyBatis的初始化做了什么 2. MyBatis基于XML配置 ...

  5. 初次认识指针:C语言*p、p以及&p的区别,*p和**p的区别?

    https://blog.csdn.net/weixin_43115440/article/details/93475460 先要理解地址和数据,你可以想象有很多盒子,每个盒子有对应的号码,那个号码叫 ...

  6. 这部分布式事务开山之作,凭啥第一天预售就拿下当当新书榜No.1?

    大家好,我是冰河~~ 今天,咱们就暂时不聊[精通高并发系列]了,今天插播一下分布式事务,为啥?因为冰河联合猫大人共同创作的分布式事务领域的开山之作--<深入理解分布式事务:原理与实战>一书 ...

  7. 关于 我的博客和Git-hub

    欢迎大家到我的GitHub 热烈讨论 https://github.com/ljj-19951010 由于另一个博客忘了怎么登陆了,换用此博客(仅供个人学习使用,请勿传播) 如果想看 特别详细的教程请 ...

  8. 第31篇-方法调用指令之invokevirtual

    invokevirtual字节码指令的模板定义如下: def(Bytecodes::_invokevirtual , ubcp|disp|clvm|____, vtos, vtos, invokevi ...

  9. [对对子队]测试报告Beta

    一.测试中发现的bug BETA阶段的新bug 描述 提出者(可能需要发现者在会议上复现) 处理人 是否解决 第四关中工作区的循环语句拖动到组件区后成本的大小比原来不一样的问题 梁河览 何瑞 是 循环 ...

  10. 关于linux7.x系列下的 systemd 的理解

    历史上Linux的启动一直采用init进程,下面的命令用来启动服务. $ sudo /etc/init.d/apache2 start #或者 $ service apache2 start 这种方法 ...