题意:

      给你n个数,让你从选择k个数,然后排成一个环(k个数的顺序随意,但是排成一个环后就不能变了),然后可以在这个环上任意的找连续w个数(w<=k),可以找多次,得到一个值等于当前找的连续的数的异或和,最后问你能找到>=L&&<=R的最大的R,L,R之间的数必须全部存在,给你N,K,L,求最大的R.

思路:

      直接先暴力找到k个数(最多C(20,6)),然后在枚举这k个数的全排列(全排列有STL函数,不想用可以自己深搜枚举),对于每一个序列求出所有可能解,找到最大的R,更新答案,这里有一个很重要的剪枝,也是这个题目的核心就是在全排列之前可以先判断一下是否可能存在可以更新R的最优解,直接深搜枚举当前这k个数(不用管顺序,是找可能存在),看看组成的最大的是否比当前的最大R大,如果不是,那么就没必要全排列再去枚举了,时间复杂度
深搜判断是 O(2^5) 而直接来全排列+枚举是 O(5! * 5 * 5),题目说的是随机数据,所以不存在那种全是极端数据,也就是所有情况都满足的数据,所以相比之下,还是加上那个剪枝比较合算。


#include<stdio.h>
#include<string.h>
#include<algorithm>

using namespace
std; int N ,K ,L ,R ,ks;
int
num[25] ,mark[130];
int
now[25]; void mk_jude(int k ,int sum)
{
if(
k == K + 1) return ;
mark[sum ^ now[k]] = 1;
mk_jude(k + 1 ,sum ^ now[k]);
mk_jude(k + 1 ,sum);
} int
jude(int k ,int sum)
{

memset(mark ,0 ,sizeof(mark));
mk_jude(1 ,0);
for(int
i = L ;i <= R ;i ++)
if(!
mark[i]) return 0;
return
1;
} void
dfs(int k ,int I)
{
if(
k == K + 1)
{
if(!
jude(1 ,0)) return;
int
tmp[25];
for(int
i = 1 ;i <= K ;i ++)
tmp[i] = now[i];
for(int
tt = 1 ;tt <= ks ;tt ++)
{

memset(mark ,0 ,sizeof(mark));
for(int
i = 1 ;i <= K ;i ++)
{
int
sum = 0;
for(int
j = 1 ;j <= K ;j ++)
{
int
a = i + j - 1;
if(
a > K) a -= K;
sum = sum ^ tmp[a];
mark[sum] = 1;
}
}
int
mk = 0;
for(int
i = L ;1 ;i ++)
if(!
mark[i])
{

mk = i - 1;
break;
}
if(
R < mk) R = mk;
next_permutation(tmp + 1 ,tmp + K + 1);
}
return ;
}
if(
I == N + 1) return;
now[k] = num[I];
dfs(k + 1 ,I + 1);
dfs(k ,I + 1);
} int main ()
{
int
i;
while(~
scanf("%d %d %d" ,&N ,&K ,&L))
{
for(
i = 1 ;i <= N ;i ++)
scanf("%d" ,&num[i]);
for(
R = 0 ,ks = 1 ,i = 2 ;i <= K ;i ++)
ks *= i;
dfs(1 ,1);
if(
R < L) R = 0;
printf("%d\n" ,R);
}
return
0;
}

hdu4876 深搜+(随机枚举剪枝)的更多相关文章

  1. poj1190 生日蛋糕(深搜+剪枝)

    题目链接:poj1190 生日蛋糕 解题思路: 深搜,枚举:每一层可能的高度和半径 确定搜索范围:底层蛋糕的最大可能半径和最大可能高度 搜索顺序:从底层往上搭蛋糕,在同一层尝试时,半径和高度都是从大到 ...

  2. HDU 3720 深搜 枚举

    DES:从23个队员中选出4—4—2—1共4种11人来组成比赛队伍.给出每个人对每个职位的能力值.给出m组人在一起时会产生的附加效果.问你整场比赛人员的能力和最高是多少. 用深搜暴力枚举每种类型的人选 ...

  3. USACO 2.3.3 Zero Sum 和为零(深搜枚举)

    Description 请考虑一个由1到N(N=3, 4, 5 ... 9)的数字组成的递增数列:1 2 3 ... N. 现在请在数列中插入“+”表示加,或者“-”表示减,抑或是“ ”表示空白,来将 ...

  4. HDU-5423 Rikka with Tree。树深搜

    Rikka with Tree 题意:给出树的定义,给出树相似的定义和不同的定义,然后给出一棵树,求是否存在一颗树即和其相似又与其不同.存在输出NO,不存在输出YES. 思路:以1号节点为根节点,我们 ...

  5. 一本通例题-生日蛋糕——题解<超强深搜剪枝,从无限到有限>

    题目传送 显然是道深搜题.由于蛋糕上表面在最底层的半径确认后就确认了,所以搜索时的面积着重看侧面积. 找维度/搜索面临状态/对象:当前体积v,当前外表面面积s,各层的半径r[],各层的高度h[]. 可 ...

  6. 一本通例题埃及分数—题解&&深搜的剪枝技巧总结

    一.简述: 众所周知,深搜(深度优先搜索)的时间复杂度在不加任何优化的情况下是非常慢的,一般都是指数级别的时间复杂度,在题目严格的时间限制下难以通过.所以大多数搜索算法都需要优化.形象地看,搜索的优化 ...

  7. 【笔记】「pj复习」深搜——简单剪枝

    深搜--简单剪枝 说在最前面: 因为马上要 NOIP2020 了,所以菜鸡开始了复习qwq. pj 组 T1 ,T2 肯定要拿到满分的,然后 T3 , T4 拿部分分, T3 拿部分分最常见的做法就是 ...

  8. 深搜+DP剪枝 codevs 1047 邮票面值设计

    codevs 1047 邮票面值设计 1999年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题目描述 Description ...

  9. Hdu3812-Sea Sky(深搜+剪枝)

    Sea and Sky are the most favorite things of iSea, even when he was a small child.  Suzi once wrote: ...

随机推荐

  1. 【HTB系列】 靶机Swagshop的渗透测试详解

    出品|MS08067实验室(www.ms08067.com) 本文作者:是大方子(Ms08067实验室核心成员) 总结与反思 使用vi提权 magento漏洞的利用 magescan 工具的使用 靶机 ...

  2. CCF(棋局评估)博弈论+对抗搜索+DFS

    201803-4 棋局评估 这题主要使用对抗搜索,也就是每一步寻找可以下棋的位置,通过在这一步下棋看最后会取的什么样的分数. #include<iostream> #include< ...

  3. WooYun-2016-199433 -phpmyadmin-反序列化-getshell

    文章参考 http://www.mottoin.com/detail/521.html https://www.cnblogs.com/xhds/p/12579425.html 虽然是很老的漏洞,但在 ...

  4. drf给上传图片重命名

    1.先在你项目中添加一个文件夹如:system 在文件夹下添加__init__.py 和storage.py文件,并在storage.py中添加如下代码: #复制代码 -- coding: UTF-8 ...

  5. 双向链表及有关操作(C语言)

    #include <stdio.h> #include <stdlib.h> /** * 含头节点双向链表定义及有关操作 */ //操作函数用到的状态码 #define TRU ...

  6. python爬虫加定时任务,制作微信提醒备忘录

    一.任务的记录与提取 1.1 制作每日任务 为了便于爬取,推荐使用网页版的在线记事本,现在这种工具很多,我选择"石墨文档"进行操作演示.记录内容的 格式可以根据自己的需求和爬虫自行 ...

  7. codefoces B - Phoenix and Beauty

    原题链接:https://codeforc.es/problemset/problem/1348/B 题意:告诉我们一个数组及其长度和k,判断是否可以构造一个新数组使得每K段长度和都相等. 思路:首先 ...

  8. 【JVM进阶之路】一:Java虚拟机概览

    1.Java简史 Java语言是一门通用的.面向对象的.支持并发的程序语言.全球从事Java相关开发的人员已经数以百万计. 从1995年"Java"正式出现以来,Java已经经历了 ...

  9. python3 多线程爬虫模板

    原文:https://www.jianshu.com/p/06ae2373f560 1 import threading # 多线程模块 2 import queue # 队列模块 3 import ...

  10. 百度开源中国(Java)面经

    一.自我介绍 面试嘛,万年不变还是自我介绍,就说说你是干嘛的(专业是啥),为什么会选择该公司(说一说自己为何向往Java开发),再谈谈自己的优点(兴趣爱好).如果人家叫停了,就别一股脑接着讲了,停下来 ...