考虑从前往后放所有轮。

如果上一轮是全中:

那么这一轮如果是补中,一定放第一次最小的,这样可以让第一次大的放在其它补中之后。

如果这一轮是失误,那么一定放总分最大的。

如果上一轮是补中:

这一轮一定放第一次最大的。

所以每次要么放补中里第一次最小的,要么放补中里第一次最大的。

最优解中一定是全中补中先交替放,直到一方不足,然后按照剩下那一放对失误轮进行贪心。

因为最后第二轮的限制,最后一轮可能是个特例,因此枚举哪轮失误是特例,再枚举失误轮贪心策略是按照总分还是第一次从大到小取,然后DP求最优解。

将补中按照第一次得分排序,设$f[i][l][r][j][k][o]$表示已经放了$i$个全中,还没放的补中是区间$[l,r]$,已经放了前$j$个非特例失误轮,特例有没有放为$k$,目前最后放的那轮是全中/补中/失误时的最优解。

时间复杂度$O(n^5)$,常数很小。

#include<cstdio>
#include<algorithm>
using namespace std;
const int N=53;
int n,flag,i,j,_,ca,cb,cc,cd,ans,f[N][N][N][N][2][3];
struct P{int x,y,z;}a[N],b[N],c[N],d,_c[N];
inline bool cmpx(const P&a,const P&b){return a.x>b.x;}
inline bool cmpz(const P&a,const P&b){return a.z>b.z;}
inline void up(int&a,int b){a<b?(a=b):0;}
void solve(){
int i,j,r,k,S,o,w,v,t,x,y,cana,cane;
for(i=0;i<=ca;i++)for(j=0;j<=cb;j++)for(r=cb;r>=j;r--)for(k=0;k<=cc;k++)for(S=0;S<=cd;S++)for(o=0;o<3;o++)f[i][j][r][k][S][o]=-1;
f[0][0][cb][0][0][0]=0;
for(i=0;i<=ca;i++)for(j=0;j<=cb;j++)for(r=cb;r>=j;r--)for(k=0;k<=cc;k++)for(S=0;S<=cd;S++)for(o=0;o<3;o++){
w=f[i][j][r][k][S][o];
if(w<0)continue;
cana=cane=1;
if(i+j+cb-r+k+S+1==n-1)cana=flag,cane=flag^1;
if(cana&&i<ca){
t=10;
if(o)t<<=1;
up(f[i+1][j][r][k][S][1],w+t);
}
if(!cane)continue;
if(j<r){
x=b[j+1].x,y=b[j+1].y;
t=x+y;
if(o==1)t=(x+y)<<1;
if(o==2)t=(x<<1)+y;
up(f[i][j+1][r][k][S][2],w+t);
x=b[r].x,y=b[r].y;
t=x+y;
if(o==1)t=(x+y)<<1;
if(o==2)t=(x<<1)+y;
up(f[i][j][r-1][k][S][2],w+t);
}
if(k<cc){
x=c[k+1].x,y=c[k+1].y;
t=x+y;
if(o==1)t=(x+y)<<1;
if(o==2)t=(x<<1)+y;
up(f[i][j][r][k+1][S][0],w+t);
}
if(S<cd){
x=d.x,y=d.y;
t=x+y;
if(o==1)t=(x+y)<<1;
if(o==2)t=(x<<1)+y;
up(f[i][j][r][k][1][0],w+t);
}
}
for(j=0;j<=cb;j++)for(o=0;o<3;o++)up(ans,f[ca][j][j][cc][cd][o]);
}
void cal(){
sort(c+1,c+cc+1,cmpz);
solve();
sort(c+1,c+cc+1,cmpx);
solve();
}
int main(){
scanf("%d",&n);
for(i=1;i<=n;i++){
scanf("%d%d",&a[i].x,&a[i].y);
a[i].z=a[i].x+a[i].y;
}
if(a[n].x==10){
n++;
flag=1;
scanf("%d%d",&a[n].x,&a[n].y);
a[n].z=a[n].x+a[n].y;
}
for(i=1;i<=n;i++){
if(a[i].x==10){ca++;continue;}
if(a[i].z==10){b[++cb]=a[i];continue;}
c[++cc]=a[i];
}
sort(b+1,b+cb+1,cmpx);
cal();
for(i=1;i<=cc;i++){
cd=1,d=c[i];
for(j=1;j<=cc;j++)_c[j]=c[j];
for(_=0,j=1;j<=cc;j++)if(j!=i)c[++_]=c[j];
cc=_;
cal();
for(cc++,j=1;j<=cc;j++)c[j]=_c[j];
}
return printf("%d",ans),0;
}

  

BZOJ3877 : [Ahoi2014&Jsoi2014]保龄球的更多相关文章

  1. [AHOI2014/JSOI2014] 解题报告

    [AHOI2014/JSOI2014] 奇怪的计算器 一个很关键的结论,任何时候每个数的相对大小是不变的. 于是可以把这个相对大小当成线段树的权值,每次只需要维护一下区间极值和tag就好了,关于操作四 ...

  2. 【BZOJ3875】[Ahoi2014&Jsoi2014]骑士游戏 SPFA优化DP

    [BZOJ3875][Ahoi2014&Jsoi2014]骑士游戏 Description  [故事背景] 长期的宅男生活中,JYY又挖掘出了一款RPG游戏.在这个游戏中JYY会扮演一个英勇的 ...

  3. BZOJ3878: [Ahoi2014&Jsoi2014]奇怪的计算器

    BZOJ3878: [Ahoi2014&Jsoi2014]奇怪的计算器 Description [故事背景] JYY有个奇怪的计算器,有一天这个计算器坏了,JYY希望你能帮助他写 一个程序来模 ...

  4. [luogu] P4040 [AHOI2014/JSOI2014]宅男计划(贪心)

    P4040 [AHOI2014/JSOI2014]宅男计划 题目背景 自从迷上了拼图,JYY就变成了个彻底的宅男.为了解决温饱问题,JYY不得不依靠叫外卖来维持生计. 题目描述 外卖店一共有N种食物, ...

  5. Bzoj 3874: [Ahoi2014&Jsoi2014]宅男计划 三分+贪心

    3874: [Ahoi2014&Jsoi2014]宅男计划 Time Limit: 1 Sec  Memory Limit: 256 MBSubmit: 861  Solved: 336[Su ...

  6. 「AHOI2014/JSOI2014」宅男计划

    「AHOI2014/JSOI2014」宅男计划 传送门 我们首先要发现一个性质:存货天数随买食物的次数的变化类似于单峰函数. 具体证明不会啊,好像是二分加三分来证明?但是没有找到明确的严格证明. 感性 ...

  7. 「AHOI2014/JSOI2014」拼图

    「AHOI2014/JSOI2014」拼图 传送门 看到 \(n \times m \le 10^5\) ,考虑根号分治. 对于 \(n < m\) 的情况,我们可以枚举最终矩形的上下边界 \( ...

  8. 「AHOI2014/JSOI2014」奇怪的计算器

    「AHOI2014/JSOI2014」奇怪的计算器 传送门 我拿到这题首先是懵b的,因为感觉没有任何性质... 后来经过同机房dalao的指导发现可以把所有的 \(X\) 放到一起排序,然后我们可以发 ...

  9. 「AHOI2014/JSOI2014」骑士游戏

    「AHOI2014/JSOI2014」骑士游戏 传送门 考虑 \(\text{DP}\). 设 \(dp_i\) 表示灭种(雾)一只编号为 \(i\) 的怪物的代价. 那么转移显然是: \[dp_i ...

随机推荐

  1. 饮冰三年-人工智能-linux-02 初始Linux

    参考博客:https://www.cnblogs.com/linhaifeng/articles/6045600.html 1:初始Linux命令 右击,开启终端,或者ctrl+alt[F1-F6]的 ...

  2. CA认证的原理和流程及https原理

    1.什么是CA证书. 看过一些博客,写的比较形象具体. ◇ 普通的介绍信 想必大伙儿都听说过介绍信的例子吧?假设 A 公司的张三先生要到 B 公司去拜访,但是 B 公司的所有人都不认识他,他咋办捏?常 ...

  3. CMD批处理——forfiles命令使用,自动删除过期备份文件

    公司服务器用来备份数据的硬盘过段时间就会被备份文件占满,弄得我老是要登录到服务器去手工删除那些老的文件,有时忘记了就会导致硬盘空间不足而无法备份.因为只要保留最近几天的备份,如果可以做一个批处理让系统 ...

  4. python requests 正则爬虫

    代码: import requests from multiprocessing import Pool from requests.exceptions import RequestExceptio ...

  5. Linux系统监控命令及定位Java线程

    1.PID.TID的区分 uid是user id,即用户id,root用户的uid是0,0为最高权限,gid是group id,用户组id,使用 id 命令可以很简单的通过用户名查看UID.GID:~ ...

  6. [POI2007]堆积木Klo

    题解: dp定义方程的时候 好像也不能都用前一个来递推..这样就不能优化了 这题看了题解才想出来... 还是很简单的啊.... 我们定义f[i]表示前i个最大收益 那么j要能从i转移就得满足a[i]- ...

  7. [转]pyCharm最新2018激活码

    https://blog.csdn.net/u014044812/article/details/78727496 因公司的需求,需要做一个爬取最近上映的电影.列车号.航班号.机场.车站等信息,所以需 ...

  8. python函数式编程——返回函数

    1.函数作为返回值 高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回. 2.闭包 注意到返回的函数在其定义内部引用了局部变量args,所以,当一个函数返回了一个函数后,其内部的局部变量还 ...

  9. Python_collections_deque双向队列

    deque:创建一个双向队列 import collections collections.deque(['nihao','x']) x.append():在列表的右边添加 x.appendleft( ...

  10. BZOJ5291/洛谷P4458/LOJ#2512 [Bjoi2018]链上二次求和 线段树

    原文链接http://www.cnblogs.com/zhouzhendong/p/9031130.html 题目传送门 - LOJ#2512 题目传送门 - 洛谷P4458 题目传送门 - BZOJ ...