热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

以dfs解决01背包——PAT(AdvancedLevel)1068FindMoreCoins(30分)

题目概述:给一组数,判断是否存在其中最小的一组子数列之和为给定数题目分析:dfs,为了找出最小的一组,我们从

在这里插入图片描述
在这里插入图片描述
题目概述:
给一组数,判断是否存在其中最小的一组子数列之和为给定数

题目分析:
dfs,为了找出最小的一组,我们从小到大排,这种情况下找出的第一个解即为最小的,同时利用flag进行记录,及时停止其他无效搜索。

dfs分析:

void dfs(int cur, vector<int> path, int w)//cur是当前浏览的位置&#xff0c;path是累积路径&#xff0c;w是累计和
{//无效退出if(flag &#61;&#61; true || w > m) return;//唯一性标识vis[cur] &#61; true;//有效退出if(w &#61;&#61; m && flag &#61;&#61; false){flag &#61; true;res &#61; path;return;}//不重复迭代for(int i &#61; 1; i <&#61; k; i&#43;&#43;){if(!vis[i]){path.push_back(coin[i]);dfs(i, path, w &#43; coin[i]);//往第i个深搜vis[i] &#61; false;path.pop_back();//回溯退回}}return;
}

参数解释&#xff1a;cur表示当前所指位置&#xff08;初始可设为0&#xff09;&#xff0c;path表示累计搜索路线&#xff0c;w表示累加和

无效退出&#xff1a;已找到答案或和超出

有效进入&#xff1a;设置vis为true

有效退出&#xff1a;第一次找到w &#61;&#61; m&#xff0c;将path存进res&#xff0c;同时设flag为真

迭代&#xff1a;对未搜索的点&#xff0c;
1.加入path
2.迭代进下一层dfs
3.回溯&#xff08;包括重置vis和pop_back&#xff09;

两处剪枝&#xff1a;

1.总和不够

if(sum < m){cout << "No Solution" << endl;return 0;}

2.过滤掉大于m的单值

//第二处剪枝k &#61; n;//k的初值,k为有效的最后一个值for(int i &#61; 1; i <&#61; n; i&#43;&#43;){if(coin[i] > m){k &#61; i - 1;break;}}

开启dfs&#xff1a;

dfs(0, res, 0);//新增一个不存在的0起点

数组从1开始记起&#xff0c;0起点可作为启动起点

完整代码&#xff1a;

#include
using namespace std;vector<int> res;//记录最终路径
bool vis[10010];//保证不重复
int coin[10010];//记录面值
bool flag &#61; false;//记录是否找到
int k;//剪枝&#xff0c;记录有效的位置
int m;//记录targetvoid dfs(int cur, vector<int> path, int w)//cur是当前浏览的位置&#xff0c;path是累积路径&#xff0c;w是累计和
{//无效退出if(flag &#61;&#61; true || w > m) return;//唯一性标识vis[cur] &#61; true;//有效退出if(w &#61;&#61; m && flag &#61;&#61; false){flag &#61; true;res &#61; path;return;}//不重复迭代for(int i &#61; 1; i <&#61; k; i&#43;&#43;){if(!vis[i]){path.push_back(coin[i]);dfs(i, path, w &#43; coin[i]);//往第i个深搜vis[i] &#61; false;path.pop_back();//回溯退回}}return;
}int main()
{int n;cin >> n >> m;int sum &#61; 0;for(int i &#61; 1; i <&#61; n; i&#43;&#43;){cin >> coin[i];sum &#43;&#61; coin[i];}//第一处剪枝if(sum < m){cout << "No Solution" << endl;return 0;}else{sort(coin &#43; 1, coin &#43; n &#43; 1);//从小到大排//第二处剪枝k &#61; n;//k的初值,k为有效的最后一个值for(int i &#61; 1; i <&#61; n; i&#43;&#43;){if(coin[i] > m){k &#61; i - 1;break;}}//开始dfsdfs(0, res, 0);//新增一个不存在的0起点if(flag &#61;&#61; true){cout << res[0];for(int i &#61; 1; i < res.size(); i&#43;&#43;)cout << " " << res[i];cout << endl;}else cout << "No Solution" << endl;}return 0;
}

总结&#xff1a;
1.res记录路径&#xff0c;vis记录是否走过&#xff0c;flag记录是否找到
2.剪枝&#xff1a;总和、个体、第一次找到
3.dfs套路&#xff1a;无效退出&#xff0c;有效进入&#xff0c;有效退出&#xff0c;无重复迭代
4.dfs迭代套路&#xff1a;加入累计路径&#xff0c;下一轮迭代&#xff0c;回溯&#xff08;vis&#43;pop&#xff09;
5.dfs参数套路&#xff1a;当前位置&#xff0c;累计路径&#xff0c;累计统计量
6.dfs开启套路&#xff1a;当前位置可加入无意义的初始启动点&#xff0c;如0


推荐阅读
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 本问题涉及在给定的无向图中寻找一个至少包含三个节点的环,该环上的节点不重复,并且环上所有边的长度之和最小。目标是找到并输出这个最小环的具体方案。 ... [详细]
  • 洛谷 P4009 汽车加油行驶问题 解析
    探讨了经典算法题目——汽车加油行驶问题,通过网络流和费用流的视角,深入解析了该问题的解决方案。本文将详细阐述如何利用最短路径算法解决这一问题,并提供详细的代码实现。 ... [详细]
  • 1、编写一个Java程序在屏幕上输出“你好!”。programmenameHelloworld.javapublicclassHelloworld{publicst ... [详细]
  • 在尝试加载支持推送通知的iOS应用程序的Ad Hoc构建时,遇到了‘no valid aps-environment entitlement found for application’的错误提示。本文将探讨此错误的原因及多种可能的解决方案。 ... [详细]
  • Hadoop MapReduce 实战案例:手机流量使用统计分析
    本文通过一个具体的Hadoop MapReduce案例,详细介绍了如何利用MapReduce框架来统计和分析手机用户的流量使用情况,包括上行和下行流量的计算以及总流量的汇总。 ... [详细]
  • 本文详细介绍了如何在PyQt5中创建简易对话框,包括对话框的基本结构、布局管理以及源代码实现。通过实例代码,展示了如何设置窗口部件、布局方式及对话框的基本操作。 ... [详细]
  • 题目概述:Sereja 拥有一个由 n 个整数组成的数组 a1, a2, ..., an。他计划执行 m 项操作,这些操作包括更新数组中的特定元素、增加数组中所有元素的值,以及查询数组中的特定元素。 ... [详细]
  • 题目描述:Balala Power! 时间限制:4000/2000 MS (Java/Other) 内存限制:131072/131072 K (Java/Other)。题目背景及问题描述详见正文。 ... [详细]
  • Gradle 是 Android Studio 中默认的构建工具,了解其基本配置对于开发效率的提升至关重要。本文将详细介绍如何在 Gradle 中定义和使用共享变量,以确保项目的一致性和可维护性。 ... [详细]
  • 本文详细探讨了HihoCoder平台上的1398号问题——最大权闭合子图的求解方法。通过具体实例,深入分析了最大权闭合子图的概念及其算法实现。 ... [详细]
  • 深入解析 C++ 中的 String 和 Vector
    本文详细介绍了 C++ 编程语言中 String 和 Vector 的使用方法及特性,旨在帮助开发者更好地理解和应用这两个重要的容器。 ... [详细]
  • 本文详细介绍了在Luat OS中如何实现C与Lua的混合编程,包括在C环境中运行Lua脚本、封装可被Lua调用的C语言库,以及C与Lua之间的数据交互方法。 ... [详细]
  • 本文详细介绍了 Redis 中的主要数据类型,包括 String、Hash、List、Set、ZSet、Geo 和 HyperLogLog,并提供了每种类型的基本操作命令和应用场景。 ... [详细]
  • hlg_oj_1116_选美大赛这题是最长子序列,然后再求出路径就可以了。开始写的比较乱,用数组什么的,后来用了指针就好办了。现在把代码贴 ... [详细]
author-avatar
密歇根的闪闪
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有