DFS之剪枝与优化

剪枝

1.优化搜索顺序:在大部分情况下,我们应该优先搜索分支较少的结点

2.排除等效冗余(在不考虑顺序的情况下,尽量用组合的方式来搜索)

3.可行性剪枝

4.最优性剪枝

5.记忆化搜索 

165. 小猫爬山 - AcWing题库

import java.util.*;public class Main{static int N = 20;static int n, m, res = N;static int[] w = new int[N];//每只小猫的数量static int[] sum = new int[N];//每个缆车已经放的小猫的重量之和public static void dfs(int u, int k){//u猫的数量,共有k个缆车//最优性剪枝if(k >= res) return;if(u == n){res = k;return;}//能在以前的车里面找到位置for(int i = 0; i < k; i ++){if(sum[i] + w[u] <= m){//可行性剪枝sum[i] += w[u];dfs(u + 1, k);sum[i] -= w[u];//回溯,恢复现场}}//新开一辆车sum[k] = w[u];//数组是从0开始的,所以这里的第k+1辆车用k表示dfs(u + 1, k + 1);sum[k] = 0;//恢复现场}public static void main(String[] args){Scanner sc = new Scanner(System.in);n = sc.nextInt();m = sc.nextInt();for(int i = 0; i < n; i ++){w[i] = sc.nextInt();}//优化搜索顺序,分支少的先搜索(重猫)Arrays.sort(w, 0, n);//排序int[] b = new int[n];for(int i = n - 1, j = 0; i >= 0; i --){b[j ++] = w[i];}for(int i = 0; i < n; i ++) w[i] = b[i];dfs(0, 0);System.out.print(res);}
}

 

166. 数独 - AcWing题库

可以用一个九位的二进制数来表示一行的状态 

import java.util.*;public class Main{static int N = 9, cnt;static char[] str;//输入输出static int[] row = new int[N];//行static int[] cel = new int[N];//列static int[][] cell = new int[3][3];//九宫格static int[] ones = new int[1 << N];//二进制状态中1的个数//二进制数中最后一个1的位置static Map<Integer, Integer> map = new HashMap<>();//初始化所有行列和九宫格都可以填1到9中的数public static void init(){for(int i = 0; i < N; i ++) row[i] = cel[i] = (1 << N) - 1;for(int i = 0; i < 3; i ++){for(int j = 0; j < 3; j ++){cell[i][j] = (1 << N) - 1;}}}//st为true表示在这个位置上填上一个t,在这个位置上去除tpublic static void draw(int x, int y, int t, boolean st){if(st) str[x * N + y] = (char)(t + '1');else str[x * N + y] = '.';int v = 1 << t;//第几位的1if(!st) v = -v;//回溯row[x] -= v;cel[y] -= v;cell[x / 3][y / 3] -= v;}//lowbit函数求二进制数的最后一个1public static int lowbit(int x){return x & -x;}//获取他能够放的所有的状态为1的位置public static int get(int x, int y){return row[x] & cel[y] & cell[x / 3][y / 3];}public static boolean dfs(int cnt){if(cnt == 0) return true;//如果空点已经没有了int minv = 10;//能填的数的个数int x = -1, y = -1;//初始化这个点的横纵坐标//找到能填的数最少的点for(int i = 0; i < N; i ++){for(int j = 0; j < N; j ++){if(str[i * N + j] == '.'){//空着的点才能填int f = get(i, j);//获取它能够放的状态if(ones[f] < minv){minv = ones[f];x = i;y = j;}}}}int state = get(x, y);//找到分支最小的那一点for(int i = state; i != 0; i -= lowbit(i)){int t = map.get(lowbit(i));draw(x, y, t, true);//进行放置if(dfs(cnt - 1)) return true;draw(x, y, t, false);//回溯}return false;//不行就返回false}//main函数public static void main(String[] args){Scanner sc = new Scanner(System.in);//获取每个状态中1的个数for(int i = 0; i < 1 << N; i ++){for(int j = 0; j < N; j ++){ones[i] += i >> j & 1;}}//二进制数中最后一个1的位置for(int i = 0; i < N; i ++) map.put(1 << i, i);while(true){String s = sc.next();//输入数据if(s.equals("end")) break;str = s.toCharArray();//转化为数组init();//初始化cnt = 81;//一共有81个空位要填for(int i = 0; i < N; i ++){for(int j = 0; j < N; j ++){//转化为二维数组来看if(str[i * N + j] != '.'){draw(i, j, str[i * N + j] - '1', true);//填上这个数cnt --;//减去空着的点数}}}dfs(cnt);//把char数组转化为字符串输出System.out.println(new String(str));}}
}

 

167. 木棒 - AcWing题库 

import java.util.*;public class Main{static int N = 70;static int length, sum, n;static int[] w = new int[N];//每根小棍的长度static boolean[] st = new boolean[N];//标记这个小棍用过了没有public static boolean dfs(int u, int s, int start){//第几根大棍,这个大棍的长度,从第几根小棍开始枚举if(u * length == sum) return true;if(s == length) return dfs(u + 1, 0, 0);//如果当前大棍已经满了for(int i = start; i < n; i ++){if(st[i]) continue;//已经用过了//可行性剪枝if(s + w[i] > length) continue;//超过大小了st[i] = true;//标记一下if(dfs(u, s + w[i], i + 1)) return true;st[i] = false;//恢复现场if(s == 0) return false;//放在第一个位置失败if(s + w[i] == length) return false;//放在最后一个位置失败int j = i;while(j < n && w[i] == w[j]) j ++;i = j - 1;}return false;}public static void main(String[] args){Scanner sc = new Scanner(System.in);while(true){length = 0;sum = 0;Arrays.fill(st, false);//多组测试数据n = sc.nextInt();if(n == 0) break;for(int i = 0; i < n; i ++){w[i] = sc.nextInt();length = Math.max(length, w[i]);sum += w[i];//所有大棍的总长度}//从大到小排序,优化搜索顺序Arrays.sort(w, 0, n);int[] b = new int[n];for(int i = n - 1, j = 0; i >= 0; i --){b[j ++] = w[i];}for(int i = 0; i < n; i ++){w[i] = b[i];}while(true){//判断总长度是不是length的倍数if(sum % length == 0 && dfs(0, 0, 0)){System.out.println(length);//因为length从小到大枚举,所以第一次成立的时候就是最小值break;}length ++;}}}
}

 

168. 生日蛋糕 - AcWing题库

 

还不是太懂,先跳一下 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/709597.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小狐狸chat2.7.2免授权修复版可用版

小狐狸chat2.7.2免授权修复版可用版 在网络上面找了好几个版本不能使用&#xff0c;今天发布这个仔细测试正常使用 主要功能&#xff1a;独立版无限多开支持分销会员充值自己APP打包小程序万能创作MJ绘图多个国内接口 国外很火的ChatGPT&#xff0c;这是一种基于人工智能技术…

《汇编语言》- 读书笔记 - 第13章-int 指令

《汇编语言》- 读书笔记 - 第13章-int 指令 13.1 int 指令13.2 编写供应用程序调用的中断例程中断例程&#xff1a;求一 word 型数据的平方主程序中断处理程序执行效果 中断例程&#xff1a;将一个全是字母&#xff0c;以0结尾的字符串&#xff0c;转化为大写主程序中断处理程序…

IDEA利用鼠标调整字体大小

就可以按住ctrl和鼠标调节代码字体的大小啦&#xff01; 如果有用&#xff0c;记得给我来个赞~ 谢啦&#xff01;

【性能测试】loadrunner12.55--知识准备

1.0. 前言 ​ 在性能测试中&#xff0c;牵扯到了许多比较杂的知识点&#xff0c;这里将给大家说一下&#xff0c;loadrunner性能测试前需要做的一些准备&#xff0c;本节中我们将先从性能测试的一些术语入手&#xff0c;再到HTTP的一些知识&#xff0c;最后导我们loadrunner12…

应用多元统计分析--多元数据的直观表示(R语言)

例1.2 为了研究全国31个省、市、自治区2018年城镇居民生活消费的分布规律&#xff0c;根据调查资料做区域消费类型划分。 指标&#xff1a; 食品x1&#xff1a;人均食品支出(元/人) 衣着x2&#xff1a;人均衣着商品支出(元/人) 居住x3&#xff1a;人均居住支出(元/人) 生活x4…

RabbitMQ实战学习

RabbitMQ实战学习 文章目录 RabbitMQ实战学习RabbitMQ常用资料1、安装教程2、使用安装包3、常用命令4、验证访问5、代码示例 一、RabbitMQ基本概念1.1. MQ概述1.2 MQ 的优势和劣势1.3 MQ 的优势1. 应用解耦2. 异步提速3. 削峰填谷 1.4 MQ 的劣势1.5 RabbitMQ 基础架构1.6 JMS 二…

Java配置49-nginx 反向代理 sftp 服务器

1. 背景 后端服务需要通过部署在跳板机上的 nginx 访问一个外网的 SFTP 服务器。 2. 方法 nginx从 1.9.0 开始&#xff0c;新增加了一个stream模块&#xff0c;用来实现四层协议的转发、代理或者负载均衡等。 首先检查 nginx 版本信息及是否安装了 stream 模块。 进入 ngi…

React入门之React_使用es5和es6语法渲染和添加class

React入门 //react的核心库 <script src"https://cdn.jsdelivr.net/npm/react17/umd/react.development.js"></script> //react操作dom的核心库&#xff0c;类似于jquery <script src"https://cdn.jsdelivr.net/npm/react-dom17/umd/react-dom.…

USB-C接口:办公新宠,一线连接笔记本与显示器

USB-C接口如今已成为笔记本与显示器连接的优选方案。无需担心正反插错&#xff0c;支持雷电4和DP视频信号输出&#xff0c;高速数据传输&#xff0c;还有最高100W的快充功能&#xff0c;真是方便又实用&#xff01; 一线连接&#xff0c;多功能融合 通过这个接口&#xff0c;你…

Unity 游戏设计模式:工厂模式

本文由 简悦 SimpRead 转码&#xff0c; 原文地址 mp.weixin.qq.com 工厂模式是一种创建型设计模式&#xff0c;它提供了一种封装对象实例化过程的方式&#xff0c;使得客户端代码与具体类的实现解耦。 在 C# 的游戏设计中&#xff0c;模式有以下作用&#xff1a; 对象的创建…

Keepalived介绍、架构和安装

Keepalived介绍、架构和安装 文章目录 Keepalived介绍、架构和安装1.Keepalived&#xff08;高可用性服务&#xff09;1.1 Keepalived介绍1.2 Keepalived 架构1.3 Keepalived 相关文件 2.Keepalived安装2.1 主机初始化2.1.1 设置网卡名和ip地址2.1.2 配置镜像源2.1.3 关闭防火墙…

mongo之常用数据库操作

目录 一、准备环境 二、日常记录及执行示范 连接数据库查询版本查询表总数模糊查询(使用正则)查询文档中数据条数排序大于等于查询有哪些库时间查询不在条件内的查询复制数据更新字段名称删除数据库 四、高阶查询 五、备份迁移数据库 总结 一、准备环境 借鉴&#xff1a;…

模型选择与评估

&#x1f6a9; 机器学习的一般流程包括&#xff1a;数据集的准备与预处理、搭建模型、模型训练、模型评估与应用。 在现实任务中&#xff0c;我们往往有多种学习算法可供选择&#xff0c;甚至对同一个学习算法&#xff0c;当使用不同的参数配置时&#xff0c;也会产生不同的模型…

模块整理!YOLOv9中的“Silence”、“RepNCSPELAN4”、“ADown”、“CBLinear”创新模块汇总!

代码链接&#xff1a;https://github.com/WongKinYiu/yolov9/tree/main 论文链接&#xff1a;YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information 大量文字及图片来袭&#xff01; 本文整理了YOLOv9中的创新模块&#xff0c;附代码和结构图&a…

【Java程序设计】【C00323】基于Springboot的高校科研信息管理系统(有论文)

基于Springboot的高校科研信息管理系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的高校科研信息管理系统&#xff0c;本系统有管理员、学校管理员、科研人员三种角色&#xff1b; 管理员&#xff1a;首页、个…

JavaWeb之 创建 Web项目,使用Tomcat 部署项目,使用 Maven 构建Web项目(一万八千字详解)

目录 前言3.1 Tomcat 简介3.1.1 什么是 Web服务器3.1.2 Tomcat 是什么3.1.3 小结 3.2 Tomcat 的基本使用3.2.1 下载 Tomcat3.2.2 安装 Tomcat3.2.3 卸载 Tomcat3.2.4 启动 Tomcat3.2.5 关闭 Tomcat3.2.6 配置 Tomcat3.2.7 在 Tomcat 中部署 Web项目 3.3 在 IDEA 中创建 Web 项目…

(C语言)二分查找

在⼀个升序的数组中查找指定的数字n&#xff0c;很容易想到的⽅法就是遍历数组&#xff0c;但是这种⽅法效率⽐较低。⽐如我买了⼀双鞋&#xff0c;你好奇问我多少钱&#xff0c;我说不超过300元。你还是好奇&#xff0c;你想知道到底多少&#xff0c;我就让你猜&#xff0c;你…

【电路笔记】-RC网络-RC积分器

RC积分器 文章目录 RC积分器1、概述2、RC积分器3、电容电压4、单脉冲 RC 积分器5、RC积分器示例6、RC 积分器作为正弦波发生器7、总结RC 积分器是一个串联的 RC 网络,可产生与积分的数学过程相对应的输出信号。 1、概述 对于无源 RC 积分器电路,输入连接到电阻,而输出电压取…

GCN 翻译 - 1

ABSTRACT 我们提出了一种可扩展的在以图结构为基础的数据上的半监督学习&#xff0c;这种方法直接作用在图数据上&#xff0c;可以看做是卷积神经网络的变种。我们选择了图谱理论里面的一阶近似作为我们的卷积结构。我们的模型能够随着图的规模线性伸缩&#xff0c;并且隐藏层…

【生态适配】亚信安慧AntDB数据库与FT-2000+/64处理器完成兼容互认

日前&#xff0c;亚信安慧AntDB数据库完成了与FT-2000/64处理器的兼容互认。经湖南亚信安慧科技有限公司&#xff08;简称“亚信安慧”&#xff09;与飞腾信息技术有限公司&#xff08;简称“飞腾公司”&#xff09;的严格测试&#xff0c;亚信安慧AntDB数据库V6.2在FT-2000/64…