bzoj 1306: [CQOI2009]match循环赛【dfs+剪枝】
大力剪枝,最后洛谷上还开了o2才过……
大概这样剪枝:
1.搜索中,一个队当前得分超过要求或者一个队剩下的比赛场数全赢也达不到要求则return;
2.注意到如果平局,最总分的贡献是2,否则是3,所以可以计算出非平局的常数,dfs中记录一下当前非平局有几场,如果超出要求或者剩下的场次全都非平局也达不到要求则return;
3.如果当前队需要全赢剩下的比赛才能达到要求,就直接使他全赢然后跳过与这个对相关的比赛;
4.如果当前队需要全赢剩下的比赛才能达到要求,就直接使他全输然后跳过与这个对相关的比赛,注意,给他对手加分的时候判断一下是否对手超出要求分,是的话就直接退出;
#include<iostream>
#include<cstdio>
using namespace std;
const int N=15,f[]={3,1,0,0};
int n,a[N],b[N],ans,s,m;
inline void dfs(int x,int y,int cw,int w)
{
	if(b[x]>a[x]||b[x]+(n-y+1)*3<a[x]||cw>s||m-w+1+cw<s)
		return;
	if(x==n&&b[x]==a[x])
	{
		ans++;
		return;
	}
    if(b[x]+(n-y+1)*3==a[x])
	{
        b[x]=a[x];
		dfs(x+1,x+2,cw+n-y+1,w+n-y+1);
        b[x]=a[x]-(n-y+1)*3;
        return;
    }
    else if(b[x]==a[x])
	{
		int f=0;
		for(int i=y;i<=n;i++)
		{
			b[i]+=3;
			if(b[i]>a[i])
				f=1;
		}
		if(!f)
			dfs(x+1,x+2,cw+n-y+1,w+n-y+1);
		for(int i=y;i<=n;i++)
			b[i]-=3;
        return;
    }
	else if(y==n)
	{
		int nw=a[x]-b[x];
		if(nw==2)
			return;
		b[y]+=f[nw];
		dfs(x+1,x+2,cw+(nw!=1),w+1);
		b[y]-=f[nw];
	}
	else
	{
		b[x]+=3;
		dfs(x,y+1,cw+1,w+1);
		b[x]-=3;
		b[y]+=3;
		dfs(x,y+1,cw+1,w+1);
		b[y]-=3;
		b[x]++,b[y]++;
		dfs(x,y+1,cw,w+1);
		b[x]--,b[y]--;
	}
}
int main()
{
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
		scanf("%d",&a[i]),s+=a[i];
	s-=n*(n-1),m=n*(n-1)/2;
	dfs(1,2,0,1);
	printf("%d\n",ans);
	return 0;
}
bzoj 1306: [CQOI2009]match循环赛【dfs+剪枝】的更多相关文章
- BZOJ1306 [CQOI2009]match循环赛/BZOJ3139 [Hnoi2013]比赛[dfs剪枝+细节题]
		地址 看数据范围很明显的搜索题,暴力dfs是枚举按顺序每一场比赛的胜败情况到底,合法就累计.$O(3^{n*(n-1)/2})$.n到10的时候比较大,考虑剪枝. 本人比较菜所以关键性的剪枝没想出来, ... 
- 【搜索】【剪枝】bzoj1306 [CQOI2009]match循环赛
		dfs+剪枝*4(通过得很勉强): 1.只枚举一半的比赛,另一半直接得出. 2.处理前缀和,若大于目标得分则剪枝 3.前缀和加上若接下来全胜的得分 仍小于 目标得分,则剪枝. 4.枚举到每个人的最后一 ... 
- [BZOJ1306] [CQOI2009] match循环赛 (搜索)
		Description Input 第一行包含一个正整数n,队伍的个数.第二行包含n个非负整数,即每支队伍的得分. Output 输出仅一行,即可能的分数表数目.保证至少存在一个可能的分数表. Sam ... 
- bzoj1306: [CQOI2009]match循环赛(模拟爆搜)
		Input第一行包含一个正整数n,队伍的个数.第二行包含n个非负整数,即每支队伍的得分.Output输出仅一行,即可能的分数表数目.保证至少存在一个可能的分数表.Sample Input 6 5 6 ... 
- BZOJ1306: [CQOI2009]match循环赛
		[传送门:BZOJ1306] 简要题意: 有n个队伍,每个队伍都要和其他队伍比一场,赢了的队得3分,输了的队不得分,打平两队各得一分,给出每个队伍的得分,求出对战方案数 题解: DFS暴搜!!一眼就觉 ... 
- bzoj 1305: [CQOI2009]dance跳舞
		题目链接 bzoj 1305: [CQOI2009]dance跳舞 题解 男,女生拆点A1A2,B1B2,拆成两点间分别连容量为K的边,限制与不喜欢的人跳舞的数量 A1连接源点容量为x,B1连接汇点容 ... 
- Bzoj 1085: [SCOI2005]骑士精神 (dfs)
		Bzoj 1085: [SCOI2005]骑士精神 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1085 dfs + 剪枝. 剪枝方法: ... 
- *HDU1455 DFS剪枝
		Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ... 
- POJ 3009 DFS+剪枝
		POJ3009 DFS+剪枝 原题: Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16280 Acce ... 
随机推荐
- MySQL Slow Log慢日志分析【转】
			如果你的MySQL出现了性能问题,第一个需要“诊断”的就是slow log(慢日志)了. slow log文件很小,使用more less等命令就足够了.如果slow log很大怎么办?这里介绍MyS ... 
- Event Logging 技术简介
			https://blog.csdn.net/xiliang_pan/article/details/41805023 
- The Unique MST-POJ1679(次小生成树)
			http://poj.org/problem?id=1679 次小生成树 #include<stdio.h> #include<string.h> #include<st ... 
- springboot整合mybatis,freemarker
			springboot 整合mybaits,,freemarker pom.xml文件 <?xml version="1.0" encoding="UTF-8&quo ... 
- 拷贝地图 CopyAndOverwriteMap()
			private void CopyAndOverwriteMap() { //Get IObjectCopy interface IObjectCopy objectCopy = new Object ... 
- kvm虚拟化学习笔记(一)之kvm虚拟化环境安装
			平时一直玩RHEL/CentOS/OEL系列的操作,玩虚拟化也是采这一类系统,kvm在RHEL6系列操作系统支持比较好,本文采用采用OEL6.3操作系统,网上所有文章都说KVM比xen简单,我怎么感觉 ... 
- django 简易博客开发 2 模板和数据查询
			首先还是贴一下项目地址 https://github.com/goodspeedcheng/sblog 因为代码全在上面 上一篇博客我们介绍了 django的安装配置,新建project,新建a ... 
- HDU 1824 Let's go home (2-SAT判定)
			Let's go home Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ... 
- Android大牛的博客
			1 谦虚的天下:http://www.cnblogs.com/qianxudetianxia/ 2 csdn博文精选:http://www.csdn.net/article/2011-08-30/30 ... 
- Hadoop0.20.203.0在关机重启后,namenode启动报错(/dfs/name is in an inconsistent state)
			Hadoop0.20.203.0在关机重启后,namenode启动报错: 2011-10-21 05:22:20,504 INFO org.apache.hadoop.hdfs.server.comm ... 
