(事实上,总是可以让每一场都比,因此$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. xmake v2.5.8 发布,新增 Pascal/Swig 程序和 Lua53 运行时支持

    xmake 是一个基于 Lua 的轻量级跨平台构建工具,使用 xmake.lua 维护项目构建,相比 makefile/CMakeLists.txt,配置语法更加简洁直观,对新手非常友好,短时间内就能 ...

  2. 每日总结:Java基本语法 (2021.9.23)

         对象:对象是类的一个实例,有状态和行为. 类:类是一个模板,它描述一类对象的行为和状态. 方法:方法就是行为,一个类可以有很多方法. 实例变量:每个对象都有独特的实例变量,对象的状态由这些实 ...

  3. 免费 CDN 玩法 —— 文件一键上传到 NPM

    前言 unpkg.jsdelivr 等站点可加速 NPM 包文件,适合作为个人网站或演示案例的免费 CDN. 虽然上传文件到 NPM 很简单,创建 package.json 然后 npm publis ...

  4. Hadoop面试题(四)——YARN

    1.简述hadoop1与hadoop2 的架构异同 1)加入了yarn解决了资源调度的问题. 2)加入了对zookeeper的支持实现比较可靠的高可用. 2.为什么会产生 yarn,它解决了什么问题, ...

  5. Coursera Deep Learning笔记 序列模型(二)NLP & Word Embeddings(自然语言处理与词嵌入)

    参考 1. Word Representation 之前介绍用词汇表表示单词,使用one-hot 向量表示词,缺点:它使每个词孤立起来,使得算法对相关词的泛化能力不强. 从上图可以看出相似的单词分布距 ...

  6. win 常用修复蓝屏,系统比对最后更新20210804

    您可以尝试以下方案: 在管理员命令提示符下键入以下命令:Dism /Online /Cleanup-Image /ScanHealth这条命令将扫描全部系统文件并和官方系统文件对比,扫描计算机中的不一 ...

  7. Scrum Meeting 1补充会议

    日期:2021年04月24日 会议主要内容概述: 本次会议于11:30举行,对项目架构做出了重要调整,并根据该调整修改了第1次例会报告中后两日计划完成的工作部分. 一.架构调整 会上讨论了用户模块相关 ...

  8. [对对子队]会议记录4.13(Scrum Meeting 4)

    今天已完成的工作 梁河览 ​ 工作内容:初步完成存档功能 ​ 相关issue:实现游戏内UI界面使用的组件 马嘉 ​ 工作内容:找到了原料组件 ​ 相关issue:实现游戏内UI界面使用的组件 吴昭邦 ...

  9. Unity 3D手游对不同分辨率屏幕的UI自适应

    目前安卓手机的屏幕大小各异,没有统一的标准,因此用Unity 3D制作的手游需要做好对不同分辨率屏幕的UI自适应,否则就会出现UI大小不一和位置错位等问题. 我们的项目在开发时的参照分辨率(Refer ...

  10. FastAPI 学习之路(二十八)使用密码和 Bearer 的简单 OAuth2

    OAuth2 规定在使用(我们打算用的)「password 流程」时,客户端/用户必须将 username 和 password 字段作为表单数据发送.我们看下在我们应该去如何实现呢. 我们写一个登录 ...