热门标签 | 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


推荐阅读
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 判断数组是否全为0_连续子数组的最大和的解题思路及代码方法一_动态规划
    本文介绍了判断数组是否全为0以及求解连续子数组的最大和的解题思路及代码方法一,即动态规划。通过动态规划的方法,可以找出连续子数组的最大和,具体思路是尽量选择正数的部分,遇到负数则不选择进去,遇到正数则保留并继续考察。本文给出了状态定义和状态转移方程,并提供了具体的代码实现。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 加密世界下一个主流叙事领域:L2、跨链桥、GameFi等
    本文介绍了加密世界下一个主流叙事的七个潜力领域,包括L2、跨链桥、GameFi等。L2作为以太坊的二层解决方案,在过去一年取得了巨大成功,跨链桥和互操作性是多链Web3中最重要的因素。去中心化的数据存储领域也具有巨大潜力,未来云存储市场有望达到1500亿美元。DAO和社交代币将成为购买和控制现实世界资产的重要方式,而GameFi作为数字资产在高收入游戏中的应用有望推动数字资产走向主流。衍生品市场也在不断发展壮大。 ... [详细]
  • 本文介绍了Windows操作系统的版本及其特点,包括Windows 7系统的6个版本:Starter、Home Basic、Home Premium、Professional、Enterprise、Ultimate。Windows操作系统是微软公司研发的一套操作系统,具有人机操作性优异、支持的应用软件较多、对硬件支持良好等优点。Windows 7 Starter是功能最少的版本,缺乏Aero特效功能,没有64位支持,最初设计不能同时运行三个以上应用程序。 ... [详细]
  • 本文讨论了一个数列求和问题,该数列按照一定规律生成。通过观察数列的规律,我们可以得出求解该问题的算法。具体算法为计算前n项i*f[i]的和,其中f[i]表示数列中有i个数字。根据参考的思路,我们可以将算法的时间复杂度控制在O(n),即计算到5e5即可满足1e9的要求。 ... [详细]
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社区 版权所有