这题官方结题报告一直在强调不难,只要注意剪枝就行。

这题剪枝就是生命....没有最优化剪枝就跪了:如果当前连续切割数加上剩余的所有切割数没有现存的最优解多的话,不需要继续搜索了

#include <cstdio>
#include <iostream>
#include <cmath>
#include <cstring>
#include <algorithm>
# define MAX 33
using namespace std; struct node {
int id,tim,total;
int fr[11];
}cuts[MAX];
int n,m,w;
int ans[MAX],final,tmp[MAX],vis[222];
bool cmp (node a,node b) {
return a.tim < b.tim;
} void dfs(int v0,int step,int cur,int num) { // 源点,切割数,当前切割时间,已经切过的水果数
if(step > final) {
final = step;
for (int i=0; i<step; i++) ans[i] = tmp[i];
}
if(step + n - v0 - 1 <= final) return; //最优化剪枝
if(m - num < 3) return ;
int cnt = 0;
for(int i=v0+1; i<n; i++) {
if(cur == 0 || cuts[i].tim - cur <= w) { //cur为零时每个点作为第一刀都有可能
cnt = 0;
int erase[15]; //之前设为全局变量....各种跪
for(int j=0; j<cuts[i].total; j++) {
if(vis[cuts[i].fr[j]] == 0) {
cnt ++;
erase[cnt] = cuts[i].fr[j];
vis[cuts[i].fr[j]] = 1;
}
}
if(cnt >= 3) {
tmp[step] = cuts[i].id;
dfs(i,step+1,cuts[i].tim,num + cnt);
}
for(int j=1; j<=cnt; j++) vis[erase[j]] = 0;
}
}
} int main() {
int T;
cin >> T;
while(T--) {
scanf("%d%d%d",&n,&m,&w);
for(int i=0; i<n; i++) {
scanf("%d%d",&cuts[i].total,&cuts[i].tim);
cuts[i].id = i+1;
for(int j=0; j<cuts[i].total; j++) {
scanf("%d",&cuts[i].fr[j]);
}
}
final = 0;
memset(vis,0,sizeof(vis));
sort(cuts,cuts+n,cmp);
dfs(-1,0,0,0);
printf("%d\n",final);
sort(ans,ans+final);
for(int i=0; i<final; i++) {
if(i != final -1)
printf("%d ",ans[i]);
else printf("%d\n",ans[final - 1]);
}
}
return 0;
}

HDU 4620 Fruit Ninja Extreme(2013多校第二场 剪枝搜索)的更多相关文章

  1. hdu 4620 Fruit Ninja Extreme

    Fruit Ninja Extreme Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  2. HDU 4620 Fruit Ninja Extreme 搜索

    搜索+最优性剪枝. DFS的下一层起点应为当前选择的 i 的下一个,即DFS(i + 1)而不是DFS( cur + 1 ),cur+1代表当前起点的下一个.没想清楚,TLE到死…… #include ...

  3. hdu 4620 Fruit Ninja Extreme(状压+dfs剪枝)

    对t进行从小到大排序(要记录ID),然后直接dfs. 剪枝的话,利用A*的思想,假设之后的全部连击也不能得到更优解. 因为要回溯,而且由于每次cut 的数目不会超过10,所以需要回溯的下标可以利用一个 ...

  4. HDU 4620 Fruit Ninja Extreme 暴搜

    题目大意:题目就是描述的水果忍者. N表示以下共有 N种切水果的方式. M表示有M个水果需要你切. W表示两次连续连击之间最大的间隔时间. 然后下N行描述的是 N种切发 第一个数字C表示这种切法可以切 ...

  5. HDU 4614 Vases and Flowers (2013多校第二场线段树)

    题意摘自:http://blog.csdn.net/kdqzzxxcc/article/details/9474169 ORZZ 题意:给你N个花瓶,编号是0 到 N - 1 ,初始状态花瓶是空的,每 ...

  6. hdu 6045: Is Derek lying? (2017 多校第二场 1001)【找规律】

    题目链接 可以暴力找一下规律 比如,假设N=7,两人有5题相同,2题不同,枚举X=0->15时,Y的"Not lying"的取值范围从而找出规律 #include<bi ...

  7. hdu4620 Fruit Ninja Extreme

    Fruit Ninja Extreme Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...

  8. 2019牛客多校第二场 A Eddy Walker(概率推公式)

    2019牛客多校第二场 A Eddy Walker(概率推公式) 传送门:https://ac.nowcoder.com/acm/contest/882/A 题意: 给你一个长度为n的环,标号从0~n ...

  9. hdu 4000 Fruit Ninja 树状数组

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4000 Recently, dobby is addicted in the Fruit Ninja. ...

随机推荐

  1. jQuery 2.2 和 1.12 新版本发布

    新年新气象,jQuery 团队于昨日发布了两个新版本:1.12 和 2.2.这两个版本都包含了大量的Bug修正和功能改进.基本上这会是3.0之前最后一次发布.不过由于3.0不做向下兼容,所以届时 jQ ...

  2. 3月6日 c#语言

    语言基础 一.输入与输出 1.Main函数: static void Main(string [] args) { }程序代码需要写在Main函数的花括号内. 2.输出: Console.Write( ...

  3. css 单位 px em rem

    http://www.cnblogs.com/leejersey/p/3662612.html

  4. TCP释放连接时为什么time_wait状态必须等待2MSL时间

    为什么上图中的A在TIME-WAIT状态必须等待2MSL时间呢? 第一,为了保证A发送的最后一个ACK报文能够到达B.这个ACK报文段有可能丢失,因而使处在LAST-ACK状态的B收不到对已发送的FI ...

  5. get top k elements of the same key in hive

    key points: 1. group by key and sort by using distribute by and sort by. 2. get top k elements by a ...

  6. Animate 动画

    angular 也提供了animate service 涉及 $animate,$animateProvider 1.2办法后通过 angular-animate.js 还扩展了一些功能 先来说说大致 ...

  7. POJ 3525 Most Distant Point from the Sea

    http://poj.org/problem?id=3525 给出一个凸包,要求凸包内距离所有边的长度的最小值最大的是哪个 思路:二分答案,然后把凸包上的边移动这个距离,做半平面交看是否有解. #in ...

  8. RFID电子标签加工的倒装工艺

    倒装对于半导体封装领域的人员而言,是再熟悉不过的了.一般我们看到的集成电路多数以塑封为主,半导体芯片和外界进行信息沟通的通道,靠的就是集成电路的管脚.如果把集成电路外面的封装去掉,会发现每个集成电路内 ...

  9. KEIL的混合编程操作

    http://hi.baidu.com/txz01/item/21ad9d75913a7b28d7a89c12 这一篇来讲讲混合编程的问题,在网上找了一下,讲混合编程的文件章也有不少,但进行实例操作讲 ...

  10. python 操作 office

    首先介绍下office win32 com接口,这个是MS为自动化提供的操作接口,比如我们打开一个WORD文档,就可以在里面编辑VB脚本,实现我们自己的效果.对于这种一本万利的买卖,Python怎么能 ...