[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/ ...
随机推荐
- xmake v2.5.8 发布,新增 Pascal/Swig 程序和 Lua53 运行时支持
xmake 是一个基于 Lua 的轻量级跨平台构建工具,使用 xmake.lua 维护项目构建,相比 makefile/CMakeLists.txt,配置语法更加简洁直观,对新手非常友好,短时间内就能 ...
- 每日总结:Java基本语法 (2021.9.23)
对象:对象是类的一个实例,有状态和行为. 类:类是一个模板,它描述一类对象的行为和状态. 方法:方法就是行为,一个类可以有很多方法. 实例变量:每个对象都有独特的实例变量,对象的状态由这些实 ...
- 免费 CDN 玩法 —— 文件一键上传到 NPM
前言 unpkg.jsdelivr 等站点可加速 NPM 包文件,适合作为个人网站或演示案例的免费 CDN. 虽然上传文件到 NPM 很简单,创建 package.json 然后 npm publis ...
- Hadoop面试题(四)——YARN
1.简述hadoop1与hadoop2 的架构异同 1)加入了yarn解决了资源调度的问题. 2)加入了对zookeeper的支持实现比较可靠的高可用. 2.为什么会产生 yarn,它解决了什么问题, ...
- Coursera Deep Learning笔记 序列模型(二)NLP & Word Embeddings(自然语言处理与词嵌入)
参考 1. Word Representation 之前介绍用词汇表表示单词,使用one-hot 向量表示词,缺点:它使每个词孤立起来,使得算法对相关词的泛化能力不强. 从上图可以看出相似的单词分布距 ...
- win 常用修复蓝屏,系统比对最后更新20210804
您可以尝试以下方案: 在管理员命令提示符下键入以下命令:Dism /Online /Cleanup-Image /ScanHealth这条命令将扫描全部系统文件并和官方系统文件对比,扫描计算机中的不一 ...
- Scrum Meeting 1补充会议
日期:2021年04月24日 会议主要内容概述: 本次会议于11:30举行,对项目架构做出了重要调整,并根据该调整修改了第1次例会报告中后两日计划完成的工作部分. 一.架构调整 会上讨论了用户模块相关 ...
- [对对子队]会议记录4.13(Scrum Meeting 4)
今天已完成的工作 梁河览 工作内容:初步完成存档功能 相关issue:实现游戏内UI界面使用的组件 马嘉 工作内容:找到了原料组件 相关issue:实现游戏内UI界面使用的组件 吴昭邦 ...
- Unity 3D手游对不同分辨率屏幕的UI自适应
目前安卓手机的屏幕大小各异,没有统一的标准,因此用Unity 3D制作的手游需要做好对不同分辨率屏幕的UI自适应,否则就会出现UI大小不一和位置错位等问题. 我们的项目在开发时的参照分辨率(Refer ...
- FastAPI 学习之路(二十八)使用密码和 Bearer 的简单 OAuth2
OAuth2 规定在使用(我们打算用的)「password 流程」时,客户端/用户必须将 username 和 password 字段作为表单数据发送.我们看下在我们应该去如何实现呢. 我们写一个登录 ...