题目:

  给定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. 十五 awk文本处理

    Awk 语法和基础命令 以行为处理单位 对数据进行逐行处理 处理完当前行,把当前行的处理结果输出后自动对下一行进行处理 直到文件中所有行处理完为止 创造者:Aho.Weinberger.Kernigh ...

  2. python3 控制结构知识及范例

    (一)三种基本控制结构 1.顺序结构:按照程序语句编写的顺序依次逐条执行 2.选择结构:根据特定的条件选择某一个分支 3.循环结构:反复执行某个或者某些操作,关注点:在什么情况下,反复执行哪一部分的操 ...

  3. [Python]逻辑运算符 and or

    复习老男孩全栈二期视频的时候 圆号老师测试的用例两个集合and 和or操作的时候的问题 >>> a = set("what") >>> b = ...

  4. windows系统快速安装pytorch的详细教程

    pip和conda的区别 之前一直使用conda和pip ,有时候经常会两者混用.但是今天才发现二者装的东西不是在一个地方的,所以发现有的东西自己装了,但是在运行环境的时候发现包老是识别不了,一直都特 ...

  5. Qt Python Scriptable Application

    Qt Python Scriptable Application eryar@163.com Abstract. Python and C++ are in many ways as differen ...

  6. Mysql性能优化全揭秘-庖丁解牛

    「为什么写」 一直想写数据库相关的文章,最直接的原因是数据库这块我们工作中每天都会用到,也是面试求职绕不开的话题,无论你是何种测试,优秀的数据库能力都会非常加分,最近我在总结数据库性能优化这块内容,性 ...

  7. 吐槽一下python

    关于python,优点有很多.例如,编码灵活,书写随意. 印象最深的就是,Duck Type.也就说,如果使用会走路和会飞来衡量鸭子, 那么如果一个物体,走路像鸭子,飞起来像鸭子,那么它就是鸭子. d ...

  8. tensorflow开发环境版本组合

    记录下各模块的版本 tensorflow 1.15.0       print tf.__version__ cuda 10.0.130            nvcc -v cudnn 7.6.4  ...

  9. OpenJDK 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000c0000000, 1073741824, 0) failed; error='Out of memory' (errno=12)

    使用docker 安装kafka时启动失败 查看报错日志 # docker logs --since 30m 71846a96e514 Excluding KAFKA_HOME from broker ...

  10. 显示二维码-智能TFT模块

    应用范例: 使用 TOPWAY Smart LCD (HMT050CC-C) 显示二维码 第一步 建立工程 ① 开 Editor 软件, 点击菜单栏建立新工程File --> New Proje ...