非常好的一道搜索题
首先没有别的好办法就只能搜,基于对称性我只要搜对角线上半部分即可
然后有些惯用的剪枝啦什么的,具体见程序
然后代码很短,然后TLE了(但好像也有人过了)
然后就不知道怎么优化了,看到CLJ大神的空间发现这道题是可以记忆化搜索的orz
首先当搜索完某个队伍的胜负情况后,观察剩下的队伍已确定的得分和最终得分之差,我们称作剩余状态
显然,我们对后面队伍胜负的搜索得到的方案数与之前的搜索状态无关
并且,像剩下三支队伍剩余状态是1 0 3和 0 3 1是等价的,方案数相同(即顺序并不影响)
也就是说如果两次搜索的剩余状态一样,我们直接加即可,不用再搜一次
因此我们想到了记忆化搜索,对于状态的判断自然而然想到用hash

 const ch:array[..] of longint=(,,);
key=; type link=^node;
node=record
num,loc:longint;
next:link;
end; var s,c,b:array[..] of longint;
a:array[..,..] of longint;
w:array[..key] of link;
ans,u,i,n,tot:longint; procedure swap(var a,b:longint);
var c:longint;
begin
c:=a;
a:=b;
b:=c;
end; function work(m:longint):longint; //排序,计算hash值
var i,j,p:longint;
begin
work:=;
for i:= to m- do
begin
p:=i;
for j:=i+ to m do
if b[j]>b[p] then p:=j;
swap(b[i],b[p]);
end;
for i:= to m do
work:=(work+sqr(b[i])*sqr(i)) mod key;
end; function calc(l,r:longint):longint;
var k,h:longint;
begin
h:=;
for k:= to n do
b[k]:=;
for k:=l to r do
begin
inc(h);
b[h]:=c[k]-s[k];
end;
calc:=work(h);
end; procedure add(x,y:longint);
var p:link;
i:longint;
begin
new(p);
inc(tot);
for i:= to n do
a[tot,i]:=b[i];
p^.loc:=tot;
p^.num:=y;
p^.next:=w[x];
w[x]:=p;
end; function find(x,y:longint):longint;
var p:link;
f:boolean;
i:longint; begin
p:=w[x];
while p<>nil do
begin
f:=true;
u:=p^.loc;
for i:= to n do
if (a[u,i]<>b[i]) then
begin
f:=false;
break;
end;
if f then exit(p^.num);
p:=p^.next;
end;
if y<>- then add(x,y); //没有重复的状态则插入
exit(-);
end; function dfs(t,j:longint):longint;
var k,h,q:longint;
begin
if t=n then
begin
if s[n]=c[n] then exit();
exit();
end;
if s[t]>c[t] then exit(); //剪枝,显然确定的得分不能大于最终得分的
if s[t]+(n+-j)*<c[t] then exit(); //剪枝,如果后面全胜也不能达到最终得分剪掉
if j=t+ then
begin
h:=calc(t,n);
q:=find(h,-); //-表示只是单纯的查询
if q<>- then exit(q); //记忆化
end;
q:=;
if j<=n then
begin
for k:= to do
begin
s[t]:=s[t]+ch[k];
s[j]:=s[j]+ch[-k];
if not((s[j]>c[j]) or (s[j]+(n+-t)*<c[j])) then q:=q+dfs(t,j+);
s[t]:=s[t]-ch[k];
s[j]:=s[j]-ch[-k];
end;
end
else if s[t]=c[t] then //搜完一支队伍我们就判重/记录剩余状态
begin
q:=dfs(t+,t+);
h:=calc(t+,n);
k:=find(h,q);
end;
exit(q);
end; begin
readln(n);
for i:= to n do
read(c[i]);
writeln(dfs(,));
end.

bzoj1306的更多相关文章

  1. 【BZOJ1306】[CQOI2009]循环赛(搜索)

    [BZOJ1306][CQOI2009]循环赛(搜索) 题面 BZOJ 洛谷 题解 爆搜一下,\(hash\)记录是否已经考虑过这个状态,记忆化解决问题. #include<iostream&g ...

  2. BZOJ1306: [CQOI2009]match循环赛

    [传送门:BZOJ1306] 简要题意: 有n个队伍,每个队伍都要和其他队伍比一场,赢了的队得3分,输了的队不得分,打平两队各得一分,给出每个队伍的得分,求出对战方案数 题解: DFS暴搜!!一眼就觉 ...

  3. BZOJ1306 [CQOI2009]match循环赛/BZOJ3139 [Hnoi2013]比赛[dfs剪枝+细节题]

    地址 看数据范围很明显的搜索题,暴力dfs是枚举按顺序每一场比赛的胜败情况到底,合法就累计.$O(3^{n*(n-1)/2})$.n到10的时候比较大,考虑剪枝. 本人比较菜所以关键性的剪枝没想出来, ...

  4. [BZOJ1306] [CQOI2009] match循环赛 (搜索)

    Description Input 第一行包含一个正整数n,队伍的个数.第二行包含n个非负整数,即每支队伍的得分. Output 输出仅一行,即可能的分数表数目.保证至少存在一个可能的分数表. Sam ...

  5. BZOJ3139/BZOJ1306 HNOI2013比赛/CQOI2009循环赛(搜索)

    搜索好难啊. 1.对于每个分数集合记忆化. 2.某人得分超过总分,剪枝. 3.某人之后全赢也无法达到总分,剪枝. 4.每有一场比赛分出胜负总分会多三分,而平局则会多两分.某人的分出胜负场次或平局场次超 ...

  6. 【搜索】【剪枝】bzoj1306 [CQOI2009]match循环赛

    dfs+剪枝*4(通过得很勉强): 1.只枚举一半的比赛,另一半直接得出. 2.处理前缀和,若大于目标得分则剪枝 3.前缀和加上若接下来全胜的得分 仍小于 目标得分,则剪枝. 4.枚举到每个人的最后一 ...

  7. bzoj1306: [CQOI2009]match循环赛(模拟爆搜)

    Input第一行包含一个正整数n,队伍的个数.第二行包含n个非负整数,即每支队伍的得分.Output输出仅一行,即可能的分数表数目.保证至少存在一个可能的分数表.Sample Input 6 5 6 ...

  8. 【BZOJ1306】match循环赛

    预先警告:我的做法代码量比较大 看完题目后看到数据n<=8, 不难想到这题可以写深搜来做 分析 比如说以数据: 3 3 3 3 为例子, 进行了三场比赛:AB AC BC: 我们只要搜索每场比赛 ...

  9. 8.3-8.7 usaco

    summary:38 vijos1002:青蛙跳河. dp+压缩.距离大于100可以直接%100.然后数据范围小了很多可以dp了. #include<cstdio> #include< ...

随机推荐

  1. linux下实现redis共享session的tomcat集群

    为了实现主域名与子域名的下不同的产品间一次登录,到处访问的效果,因此采用rediss实现tomcat的集群效果.基于redis能够异步讲缓存内容固化到磁盘上,从而当服务器意外重启后,仍然能够让sess ...

  2. Java基础--继承方法调用顺序

    最近因为面试的原因,回过头来复习基础的知识,都忘光了,准备买本面试书回来啃. 我先把自己测试的结论总结写出来,以后忘记再来看看 如果b类继承自a类,在main方法中new出b的对象(不带参数),那么他 ...

  3. web前端开发中的浏览器兼容性总结

    1.居中问题 div里的内容,IE默认为居中,而FF默认为左对齐,可以尝试增加代码margin: 0 auto; 2.高度问题 两上下排列或嵌套的div,上面的div设置高度(height),如果di ...

  4. vim 编辑器笔记

    vim 编辑器 命令模式(默认),尾行模式 : / 两种方式 (Esc比较慢,连续连词esc,删除全部尾行内容),编辑模式 a,i,o,s :q 退出编辑不保存 :wq 保存编辑并退出 :w 保存并写 ...

  5. ASP.NET得到系统相关信息

      1. 在ASP.NET中专用属性: 获取服务器电脑名:Page.Server.ManchineName 获取用户信息:Page.User 获取客户端电脑名:Page.Request.UserHos ...

  6. 如何处理Tomcat日志catalina.out日志文件过大的问题

    tomcat默认日志文件为catalina.out,随着系统运行时间的增加,该日志文件大小会不断增大,甚至增大到G级.不仅会导致我们无法使用常规工具查找系统问题,而且会影响tomcat性能(比如我在维 ...

  7. PC110302/UVA10010

    下周开始就省选了,ACM的日子在今年内应该就会结束了,大三了,最后一次机会了,小小感伤一下-- 今天广州下大雨,心情怪怪的,感觉码不出质量高的,又很久没做过PC了,就刷刷水题吧. 老实说Program ...

  8. (转)JSP中四种传递参数的方法:

    1.form表单 2.request.setAttribute();和request.getAttribute(); 3.超链接:<a herf="index.jsp"?a= ...

  9. DOM中的范围 createRange()

    学习<JavaScript 高级程序设计> 12章dom范围的笔记 dom2级在Document类型中定义了 createRange()方法: 创建range对象很简单 var range ...

  10. 实现 winform 异步跨线程访问UI控件

    在开发winform时经常会用到多线程防止界面出现假死现象,比如当你单击某个按钮时,需要执行很多代码,但是在执行过程中想实时的将当前执行的情况报告给用户,类型进度条或文本什么的. 这个时候很显然,如果 ...