比赛 match

Description

有 N 支队伍打比赛。已知有如下条件:

• 每支队伍恰好打了 4 场比赛

• 对于一场比赛,如果是平局,双方各得 1 分;否则胜者得 3 分,负者不得分

给定每支队伍的初始分数(这时候还没有发生任何比赛)。问编号为 1 的队伍在最优情况下的名次是多 少。

Input

输入的第一行有一个整数 N (5 ≤ N ≤ 50) 。

接下来一行 N 个整数,依次描述编号为 1 ∼ N 的队伍的初始分数。

Output

输出一行一个整数,描述最优情况下,编号为 1 的队伍的名次。

Sample Input

50

0 4 1 10 4 9 3 2 9 5 2 3 1 9 3 10 4 7 2 1 8 9 4 9 1 2 9 6 9 3 8 6 1 5 7 1 3 5 6 8 1 8 9 2 10 5 3 5 2 2

Sample Output

1

解析

这道题目盯着题解看了半个多小时硬是没看懂,所以决定自己写一篇...

这道题可以考虑搜索,

设当前状态为(\(x\),\(w\),\(l\),\(d\)),

其中\(x\)表示当前是第几队,

\(w\)表示(1~\(x\)-1)中的队与( \(x\)~\(n\))中的队比赛赢了\(w\)场,\(l\),\(s\)也一样。

那么,考虑状态转移,

在每个阶段,考虑当前的队与前面的队(即1~\(x\)-1)的比赛情况和与后面的队的比赛情况

开六重循环,逐个枚举\(x\)队赢的场数\(i\),输的场数\(j\),平的场数\(k\),

以及与前面的队比赛的赢的场数\(ni\),输的场数\(nj\),平的场数\(nk\)。

那么,在转移(即搜索到\(x\)+1队)时,

w就应该加上\(i-ni\)(因为赢了(减掉\(ni\)是因为这是对于前面的队(1~\(x\)-1)的影响,而不是对后面的)),

再减去\(nj\)(因为和前面扯平了(别忘了\(w\)的含义,我们已经到了第\(x\)+1层)),

\(l\),\(d\)也同理。

而当\(x\)=\(n\)+1时,如果\(w\),\(l\),\(d\)都等于0,即当前状态可行,就返回0,

并且设\(f[x][opt][min][max][d]\)表示递归到\(x\)队,

如果\(opt\)=1,则\(min\)表示\(w\),\(max\)表示\(l\),如果\(opt\)=0,就相反。(可以省空间,当然四维数组也可以)

\(d\)就表示平局的次数。

那么在枚举的时候更新就行了。

另外,还有一个剪枝,

当\(w\)>4且\(l\)>4,或\(d\)>4时,可以直接返回INF,

因为这种情况下,就表示在(1~x-1)中一定存在两个队对( x~n)中的两个队产生了影响,

那么实际上,(1~x-1)中的这两个队的影响就可以相互抵消掉(即让他们两互相比赛) (口胡证明请自行理解下哈)

那么,初始状态就让第一队全部获胜(即(2,4,0,0))就行了!

还有什么不懂的看下代码吧(也可以在评论区里问):

#include<bits/stdc++.h>
using namespace std; inline int read(){
int sum=0,f=1;char ch=getchar();
while(ch>'9' || ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0' && ch<='9'){sum=sum*10+ch-'0';ch=getchar();}
return f*sum;
} const int INF=0x3f3f3f3f;
int n,a[100001];
int f[51][2][5][501][5]; int dfs(int x,int w,int l,int d){
if(x==n+1) return !w&&!l&&!d? 0:INF;
if((w>4&&l>4)||d>4) return INF;
int &ret=f[x][(w<l)][min(w,l)][max(w,l)][d];
if(ret+1) return ret;
ret=INF;
for(int i=0;i<=4;i++)/*x队的胜利次数*/{
for(int j=0;j<=4-i;j++)/*x队的失败次数*/{
int k=4-i-j;//x队的平局次数
for(int ni=0;ni<=min(l,i);ni++)/*x队与1~(x-1)队中比赛获胜的次数*/
for(int nj=0;nj<=min(w,j);nj++)/*x队与1~(x-1)队中比赛失败的次数*/
for(int nk=0;nk<=min(k,d);nk++)/*x队与1~(x-1)队中比赛平局的次数*/
ret=min(ret,dfs(x+1,w-ni+i-nj,l-nj+j-ni,d-nk+k-nk)+(a[x]+3*i+k>a[1]));
}
}
return ret;
} int main(){
memset(f,-1,sizeof(f));
n=read();
for(int i=1;i<=n;i++) a[i]=read();
a[1]+=12;
printf("%d\n",dfs(2,4,0,0)+1);
return 0;
}

题解 比赛 match的更多相关文章

  1. 题解-比赛CF1332

    题解-比赛CF1332 比赛CF1332 [A] [B] [C] [D] [E] [F] [G] [A]Exercising Walk Exercising Walk \(T\) 组测试数据,每次给定 ...

  2. AtCoder Grand Contest 031题解

    题面 传送门 题解 比赛的之后做完\(AB\)就开始发呆了--简直菜的一笔啊-- \(A - Colorful\ Subsequence\) 如果第\(i\)个字母选,那么它前面任意一个别的字母的选择 ...

  3. poj2699

    神题目=神题解+神读入 题意:n个人比赛, 两两比,共n*(n-1), 赢得1分, n<=10(这给了我们枚举的暗示),如果一个人打败了所有比自己分数高的人, 或者他本身就是分数最高的, 那么他 ...

  4. upc组队赛4 TV Show Game 【2-SAT】

    TV Show Game 题目描述 Mr. Dajuda, who is famous for a TV show program, occasionally suggests an interest ...

  5. Lesson 8 The best and the worst

    Text Joe Sanders has the most beautiful garden in our town. Nearly everbody enters for 'The Nicest G ...

  6. 从零开始之ecshop基础篇(17)

    目标:基于自定义的mvc框架开发的案例(项目) 项目周期    需求分析 典型的业务逻辑:    电子商务:商城(京东),B2C,C2C(淘宝),团购,秒杀,代购 内容管理:新浪门户类,优酷视频管理, ...

  7. 领域驱动设计(DDD:Domain-Driven Design) 介绍

    Eric Evans的“Domain-Driven Design领域驱动设计”简称DDD,Evans DDD是一套综合软件系统分析和设计的面向对象建模方法,本站Jdon.com是国内公开最早讨论DDD ...

  8. ACM-ICPC 2018 沈阳赛区网络预赛 F. Fantastic Graph (贪心或有源汇上下界网络流)

    "Oh, There is a bipartite graph.""Make it Fantastic."X wants to check whether a ...

  9. hdu 5616

    Jam's balance Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tot ...

随机推荐

  1. 初学K3Cloud开发

    1.BOS中在新建的空白对象中添加一个下推按钮 1.点击“菜单集合”属性 2.在打开的窗体中,点中“工具条”,新增一个按钮 3.将新增的按钮标题改为“下推”,并配置点击事件 列表菜单增加“下推”类似, ...

  2. SQL SERVER 数据有CHAR(10),CHAR(13),CHAR(9)隐藏字符

    原文:SQL SERVER 数据有CHAR(10),CHAR(13),CHAR(9)隐藏字符 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/Givi ...

  3. 栈与队列基本操作 Java实现

    一.顺序栈 //数组实现顺序栈 public class OrderStack { private String[] elem; private int top; OrderStack(int k) ...

  4. 如果你的评论被WordPress的Akismet插件屏蔽,怎么解封?

    Akismet是Matt Mullenweg早期创办的一个项目,现在已经是Automattic公司的一个专注于剿杀垃圾评论的产品.在Wordpress用户中使用最多,z-blog也有用户在用,由于垃圾 ...

  5. C# 日期格式化以及日期常用方法

    一.日期格式化 1.ToString() d 月中的某一天.一位数的日期没有前导零. dd 月中的某一天.一位数的日期有一个前导零. ddd 周中某天的缩写名称,在 AbbreviatedDayNam ...

  6. 父窗体的委托,子窗体注册,this.Owner是关键

    //声明委托 public delegate void RefreshParentHandler<T>(T obj); //父窗体的委托 public RefreshParentHandl ...

  7. Linux服务器不关机新增硬盘的方法

    在开机状态下,插入磁盘之后,执行如下命令: ls /sys/class/scsi_host/host0 host1 host2 echo "- - -" > /sys/cla ...

  8. MFC六大核心机制

    MFC六大核心机制概述 我们选择了C++,主要是因为它够艺术.够自由,使用它我们可以实现各种想法,而MFC将多种可灵活使用的功能封装起来,我们岂能忍受这种“黑盒”操作?于是研究分析MFC的核心机制成为 ...

  9. wpf DrawingImage 奇葩问题

    使用wpf drawingImage绘图是,会出现很奇怪的坐标问题,这个问题困扰很久 当在DrawingGroup中绘图的时候,坐标始终会从(0,0)开始无论设置多少值,奇怪一比 解决方法:首先在Dr ...

  10. 关于mysql事务的几件小事

    零.MyISAM和InnoDB关于锁的区别 ①MyISAM默认用的是表级锁,不支持行级锁. ②InnoDB默认用的是行级锁,也支持表级锁. ③共享锁和排它锁的兼容性 |X|排它锁|共享锁| -|-|- ...