题目:

  给定N 个整数(可能有负数),从中选择 K个数,使得这 K个数之和恰好等于一个给定的整数 X;如果有多种方案,那么选择它们中元素平方和最大的一个。例如,从4个整数{ 2, 3, 3 ,4}中选择 2个数(集合中的每一个数只能被选一次),使它们的和为 6。显然有两种方案{2,4}和{3, 3},其中平方和最大的方案为{2, 4}。数据保证存在唯一。

输入格式:

第一行给出 一个正整数 N( 1<=N<=20)

第二行给出N个整数(可能有正有负,可能不按数的大小顺序给出),中间以空格隔开。

第三行给出选择元素 K个数 ,以及它们的和 X

输出格式:

按递增的方式输出序列。

输入样例:

4   //4个元素

2 3 3 4 //4个元素的值

2 6 //选择 2个元素,之和为 6

输出样例

2 4

直接给出代码。

自我规定:当有多个递归边界时,通常把”判断是否是答案“的条件作为递归边界一

 #include<iostream>
#include<vector>
#include<algorithm>
using namespace std; const int maxn = ;
int A[maxn] = {};
int n,k,x,maxSumSqu= -;
vector<int> temp,ans;
void DFS(int index, int nowK,int sum,int sumSqu) {
if(nowK == k && sum == x) {//递归边界一
if(maxSumSqu < sumSqu) {
maxSumSqu = sumSqu;
ans = temp; //vector之间等号赋值,仅限 Int
}
return ;
}
if(index == n || nowK > k || sum > x) return ;//递归边界二
temp.push_back(A[index]);
DFS(index+,nowK+1,sum+A[index],sumSqu+A[index]*A[index]); //"选择"index号数
temp.pop_back();
DFS(index+,nowK,sum,sumSqu);//"不选择"index号数
} int main() {
cin>>n;
for(int i = ; i < n; ++i)
cin>>A[i];
cin>>k>>x;
DFS(,,,);//初始参数一般都为 0
sort(ans.begin(),ans.end());
for(int i = ; i < ans.size(); ++i) {
if(i > ) printf(" ");
printf("%d",ans[i]);
}
return ;
}

运行结果:

题目修改:

假设 N个整数中的每一个都可以被选择多次,那么选择 K个数,使得 K个数之和恰好为X。

只需修改一处代码即可,那么可以持续选择index号数,直至不再选择index号数,再转入“不选index号数”的分支。

 #include<iostream>
#include<vector>
#include<algorithm>
using namespace std; const int maxn = ;
int Set[maxn] = {};
int n,x,sum,MAXSqu= -;
vector<int> temp,ans;
void DFS(int index, int nowX,int nowSum,int nowSqu) {
if(nowX == x && nowSum == sum) {//递归边界一
if(MAXSqu < nowSqu) {
MAXSqu = nowSqu;
ans = temp; //vector之间等号赋值,仅限 Int
}
return ;
}
if(index == n || nowX > x || nowX > sum) return ;//递归边界二 temp.push_back(Set[index]);//保存当前元素
DFS(index, nowX+,nowSum + Set[index],nowSqu +Set[index]*Set[index]);//“选择”当前 index号数
temp.pop_back();
DFS(index + ,nowX,nowSum,nowSqu); //“不选择”当前 index 号数
} int main() {
cin>>n;
for(int i = ; i < n; ++i)
cin>>Set[i];
cin>>x>>sum;
DFS(,,,);
sort(ans.begin(),ans.end());
for(int i = ; i < ans.size(); ++i) {
if(i > ) printf(" ");
printf("%d",ans[i]);
}
return ;
}

深度优先搜索DFS---最优子序列求和问题(1)的更多相关文章

  1. 深度优先搜索 DFS 学习笔记

    深度优先搜索 学习笔记 引入 深度优先搜索 DFS 是图论中最基础,最重要的算法之一.DFS 是一种盲目搜寻法,也就是在每个点 \(u\) 上,任选一条边 DFS,直到回溯到 \(u\) 时才选择别的 ...

  2. 深度优先搜索DFS和广度优先搜索BFS简单解析(新手向)

    深度优先搜索DFS和广度优先搜索BFS简单解析 与树的遍历类似,图的遍历要求从某一点出发,每个点仅被访问一次,这个过程就是图的遍历.图的遍历常用的有深度优先搜索和广度优先搜索,这两者对于有向图和无向图 ...

  3. 利用广度优先搜索(BFS)与深度优先搜索(DFS)实现岛屿个数的问题(java)

    需要说明一点,要成功运行本贴代码,需要重新复制我第一篇随笔<简单的循环队列>代码(版本有更新). 进入今天的主题. 今天这篇文章主要探讨广度优先搜索(BFS)结合队列和深度优先搜索(DFS ...

  4. 深度优先搜索DFS和广度优先搜索BFS简单解析

    转自:https://www.cnblogs.com/FZfangzheng/p/8529132.html 深度优先搜索DFS和广度优先搜索BFS简单解析 与树的遍历类似,图的遍历要求从某一点出发,每 ...

  5. 【算法入门】深度优先搜索(DFS)

    深度优先搜索(DFS) [算法入门] 1.前言深度优先搜索(缩写DFS)有点类似广度优先搜索,也是对一个连通图进行遍历的算法.它的思想是从一个顶点V0开始,沿着一条路一直走到底,如果发现不能到达目标解 ...

  6. 用深度优先搜索(DFS)解决多数图论问题

    前言 本文大概是作者对图论大部分内容的分析和总结吧,\(\text{OI}\)和语文能力有限,且部分说明和推导可能有错误和不足,希望能指出. 创作本文是为了提供彼此学习交流的机会,也算是作者在忙碌的中 ...

  7. 深度优先搜索(DFS)

    [算法入门] 郭志伟@SYSU:raphealguo(at)qq.com 2012/05/12 1.前言 深度优先搜索(缩写DFS)有点类似广度优先搜索,也是对一个连通图进行遍历的算法.它的思想是从一 ...

  8. 算法总结—深度优先搜索DFS

    深度优先搜索(DFS) 往往利用递归函数实现(隐式地使用栈). 深度优先从最开始的状态出发,遍历所有可以到达的状态.由此可以对所有的状态进行操作,或列举出所有的状态. 1.poj2386 Lake C ...

  9. HDU(搜索专题) 1000 N皇后问题(深度优先搜索DFS)解题报告

    前几天一直在忙一些事情,所以一直没来得及开始这个搜索专题的训练,今天做了下这个专题的第一题,皇后问题在我没有开始接受Axie的算法低强度训练前,就早有耳闻了,但一直不知道是什么类型的题目,今天一看,原 ...

  10. [LeetCode OJ] Word Search 深度优先搜索DFS

    Given a 2D board and a word, find if the word exists in the grid. The word can be constructed from l ...

随机推荐

  1. MySql新版本安装配置

    版本:mysql-5.7.16-winx64 平台Windows 7 x64 1.进入mysql主目录(建议将其移到C或D盘的根目录,并改名为mysql) 2.配置path环境变量(如D:\JAVA\ ...

  2. 非常NB的一款快捷启动软件--Merry

    Merry 被设计为了能将日常重复性操作简化为一个快捷键或者命令.Merry 采用完全开放的体系, 可以使用 Lua 或者外部程序来扩展 Merry 的功能. 另附一个自己扩展的LUA脚本: --启动 ...

  3. 第3章 JDK并发包(五)

    3.3 不要重复发明轮子:JDK的并发容器 3.3.1 超好用的工具类:并发集合简介 JDK提供的这些容器大部分在java.util.concurrent包中. ConcurrentHashMap:这 ...

  4. 20200105--python学习第七天

    今日内容 深浅拷贝 文件操作 内容回顾及补充 1.内容回顾 计算机基础 编码 语法 if/while/for 数据类型 type/id/range 运算符 2.面试题 a.公司线上的系统用的是什么? ...

  5. mount.nfs: Stale file handle的解决方法

    在NFS客户端挂载rpc共享服务的时候出现这个问题 # mount -t nfs 192.168.20.6:/data /mnt mount.nfs: Stale file handle 原因是当cl ...

  6. ELF文件之四——使用链接脚本-2个函数-data

    main.c ; int main() { ; } int add() { ; } main.o 反汇编可以看到多了.text节的反汇编,存储的是全局变量的初始化数值 main.o对比,text段后面 ...

  7. jmeter接口测试(登录、注册)

    Jmeter 进行接口测试流程: Jmeter 的下载地址:http://jmeter.apache.org/download_jmeter.cgi 下面举例说明使用流程,有两种参数传递的方式,我们以 ...

  8. centos输入正确密码后依旧无法登陆问题

    输入正确用户名和密码时依旧无法登录. 进入单用户模式重置密码: 开机启动时,按‘E’键(倒计时结束前)进入界面 选择第二项,按‘E’键再次进入 在最后一行添加‘ 1’(空格 1) 回车键保存,回到该界 ...

  9. 标准 I/O 和管道

    1.标准输入和输出1>程序:指令+数据(指令服务于数据) 读入数据:input 输出数据:output 2>三种 I/O 设备 Linux 给程序提供三种 I/O 设备 标准输入(STDI ...

  10. ES6 - 基础学习(8): Promise 对象

    概述 Promise是异步编程的一种解决方案,比传统的解决方案(多层嵌套回调.回调函数和事件)更强大也更合理.从语法上说,Promise是一个对象,从它可以获取异步操作的消息,Promise 还提供了 ...