[Wc2007]剪刀石头布
[Wc2007]剪刀石头布
http://www.lydsy.com/JudgeOnline/problem.php?id=2597
Time Limit: 20 Sec Memory Limit: 128 MBSec Special Judge
Description
Input
Output
Sample Input
0 1 2
0 0 2
2 2 0
Sample Output
0 1 0
0 0 1
1 0 0
#include<queue>
#include<cstdio>
#include<cstring>
#define N 5500
#define M 50000
using namespace std;
int win[],cnt;
int src,decc;
int front[N],nxt[M],to[M],tot=,from[M];
int cost[M],cap[M],pre[N];
int dis[N],ans[][];
bool v[N];
queue<int>q;
void add(int u,int v,int w,int val)
{
to[++tot]=v; nxt[tot]=front[u]; front[u]=tot; cap[tot]=w; cost[tot]=val; from[tot]=u;
to[++tot]=u; nxt[tot]=front[v]; front[v]=tot; cap[tot]=; cost[tot]=-val; from[tot]=v;
}
bool spfa()
{
memset(dis,,sizeof(dis));
memset(v,,sizeof(v));
dis[src]=; q.push(src); v[src]=true;
int now;
while(!q.empty())
{
now=q.front();
q.pop(); v[now]=false;
for(int i=front[now];i;i=nxt[i])
{
if(cap[i]>&&dis[to[i]]>dis[now]+cost[i])
{
dis[to[i]]=dis[now]+cost[i];
pre[to[i]]=i;
if(!v[to[i]])
{
v[to[i]]=true;
q.push(to[i]);
}
}
}
}
return dis[decc]<2e9;
}
int main()
{
int n,x;
scanf("%d",&n);
cnt=n+;decc=n+;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
{
scanf("%d",&x);
if(j>=i) continue;
if(!x)
{
win[j]++;
ans[j][i]=;
cnt++;
add(src,cnt,,);
add(cnt,j,,);
}
else if(x==)
{
win[i]++;
ans[i][j]=;
cnt++;
add(src,cnt,,);
add(cnt,i,,);
}
else
{
cnt++;
add(src,cnt,,);
add(cnt,i,,);
add(cnt,j,,);
}
}
for(int i=;i<=n;i++)
{
for(int j=;j<=win[i];j++) add(i,decc,,);
for(int j=win[i]+;j<n;j++) add(i,decc,,j-);
}
int tmp=;
while(spfa())
{
tmp+=dis[decc];
for(int i=pre[decc];i;i=pre[from[i]])
{
cap[i]--; cap[i^]++;
}
}
for(int i=front[src];i;i=nxt[i])
{
int j1=front[to[i]],j2=nxt[j1];
if(cap[j1]) ans[to[j2]][to[j1]]=;
else ans[to[j1]][to[j2]]=;
}
int sum=n*(n-)*(n-)/;
for(int i=;i<=n;i++)
sum-=win[i]*(win[i]-)/;
printf("%d\n",sum-tmp);
for(int i=;i<=n;i++)
{
for(int j=;j<n;j++)
printf("%d ",ans[i][j]);
printf("\n");
}
}
错误:一边spfa一边更新答案
原因:费用流也有退流
[Wc2007]剪刀石头布的更多相关文章
- 2597: [Wc2007]剪刀石头布
2597: [Wc2007]剪刀石头布 链接 分析: 费用流. 首先转化一下问题,整张图最优的情况是存在$C_n^3$个,即任意3个都行,然后考虑去掉最少不满足的三元环. 如果u赢了v,u向v连一条边 ...
- [Wc2007]剪刀石头布[补集转化+拆边]
2597: [Wc2007]剪刀石头布 Time Limit: 20 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 1157 Solved: ...
- 【BZOJ2597】[Wc2007]剪刀石头布 最小费用流
[BZOJ2597][Wc2007]剪刀石头布 Description 在一些一对一游戏的比赛(如下棋.乒乓球和羽毛球的单打)中,我们经常会遇到A胜过B,B胜过C而C又胜过A的有趣情况,不妨形象的称之 ...
- [bzoj2597][Wc2007]剪刀石头布_费用流
[Wc2007]剪刀石头布 题目大意:https://www.lydsy.com/JudgeOnline/problem.php?id=2597 题解: 发现直接求三元环不好求,我们考虑任选三个点不是 ...
- BZOJ2597 [Wc2007]剪刀石头布(最小费用最大流)
题目大概是说n个人两两进行比赛,问如何安排几场比赛的输赢使得A胜B,B胜C,C胜A这种剪刀石头布的三元组最多. 这题好神. 首先,三元组总共有$C_n^3$个 然后考虑最小化不满足剪刀石头布条件的三元 ...
- bzoj2597: [Wc2007]剪刀石头布
Description 在一些一对一游戏的比赛(如下棋.乒乓球和羽毛球的单打)中,我们经常会遇到A胜过B,B胜过C而C又胜过A的有趣情况,不妨形象的称之为剪刀石头布情况.有的时候,无聊的人们会津津乐道 ...
- BZOJ2597 WC2007剪刀石头布(费用流)
考虑使非剪刀石头布情况尽量少.设第i个人赢了xi场,那么以i作为赢家的非剪刀石头布情况就为xi(xi-1)/2种.那么使Σxi(xi-1)/2尽量小即可. 考虑网络流.将比赛建成一排点,人建成一排点, ...
- bzoj 2597 [Wc2007]剪刀石头布——费用流
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2597 三个人之间的关系,除了“剪刀石头布”,就是有一个人赢了2局:所以考虑算补集,则每个人对 ...
- 【bzoj2597】[Wc2007]剪刀石头布 动态加边费用流
题目描述 在一些一对一游戏的比赛(如下棋.乒乓球和羽毛球的单打)中,我们经常会遇到A胜过B,B胜过C而C又胜过A的有趣情况,不妨形象的称之为剪刀石头布情况.有的时候,无聊的人们会津津乐道于统计有多少这 ...
随机推荐
- Python:模块学习——os模块
os模块提供了多个访问操作系统服务的功能 os模块中一些重要的函数和变量 os.name 显示当前使用平台 os.getcwd() 显示当前Python脚本工作路径 os.listdir('dirna ...
- C/C++学习计划
学习内容:C语言程序设计精髓/计算机程序设计(C++) 学习理由:基础比较薄弱,想先打好基础. 时间安排:每天学习两课时. mooc地址:http://www.icourse163.org/home. ...
- Mac10.11.2 Apache 服务配置
系统默认是隐藏apache安装目录的,但我们可以通过“命令行”或者“文件夹前往”的方式找到它.它是安装在系统的私有目录下,也就是/private/etc下面,因为它是隐藏的,所以我们无法通过界面找到它 ...
- erlang调优方法
1. 来自Scaling Erlang的方法 内核调优: # Increase the ipv4 port range: sysctl -w net.ipv4.ip_local_port_range= ...
- 对IT行业的看法和对软件工程的理解
现在社会上IT行业的人才需求越来越大,而作为一个学软件工程的大学生,我认为IT行业是一个前景十分强大的发展方向,而且现在的社会越来越信息化,未来的生活中,电脑肯定是不可缺少的,所以我认为IT行业这是一 ...
- WordPress使用淘宝IP地址库的API显示评论者的位置信息(二)
1 淘宝IP地址库的接口说明 在上一篇文章<WordPress使用淘宝IP地址库的API显示评论者的位置信息(一)>中,vfhky使用了新浪工具提供的这个IP接口显示博客评论者的位置信息. ...
- yarn add & yarn global add
yarn global add & add -D https://yarnpkg.com/zh-Hans/docs/cli/add#toc-commands $ yarn global add ...
- 第149天:javascript中this的指向详解
js中的this指向十分重要,了解js中this指向是每一个学习js的人必学的知识点,今天没事,正好总结了js中this的常见用法,喜欢的可以看看: 1.全局作用域或者普通函数中this指向全局对象w ...
- Vue使用,异步获取日期时间后格式成"/Date(1333245600000+0800)/" 转换成正常格式
js从后台mvc中日期获取,结果格式成"/Date(1333245600000+0800)/"了,当然不能这样展显给用户了,要转换,方法如下: function data_stri ...
- mvc4扩展方法
制作扩展方法,方便网页中使用,下面做了两个例子 using System; using System.Collections.Generic; using System.Linq; using Sys ...