题目:

  给定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. 实验1: Cisco路由器基础配置

    实验 1:  Cisco路由器基础配置 1.    路由器的运行模式:Router>    用户模式,通常用来查看统计信息,但不能修改路由器的设置.Router#    特许模式,可以查看并修改 ...

  2. java配置文件集

    <!-- 激活组件扫描功能,扫描aop的相关组件组件 --> <context:component-scan base-package="com.yingjun.ssm.a ...

  3. 读取sysTreeview32和SysListView32

    #include <stdio.h> #include <windows.h> #include <commctrl.h> int main(void) { /* ...

  4. Java12可用新特性一览,了解一下没有错

    你有一个思想,我有一个思想,我们交换后,一个人就有两个思想 If you can NOT explain it simply, you do NOT understand it well enough ...

  5. webdriver的常用方法

    webdriver的常用方法 click():点击元素 clear():清除文本 send_keys(value):模拟按键输入 # -*- coding:utf-8 -*- from seleniu ...

  6. C 语言宏定义函数编写时 do-while 的妙用和一些注意事项

    在 C 语言中,我们都知道可以用宏定义来编写函数,一般称为宏函数.如果一个宏函数比较复杂,那么在编写这样的宏函数是有一定技巧和注意事项的.文章给出一些我认为值得关注的地方,以及一些注意事项(个人建议) ...

  7. spyder学习记录---如何调试

    调试技巧: 当我们想单步执行某段代码(但是不进入调用的函数)时,点击运行当前行. 当我们想进入某个函数内部进行调试,在函数调用处点击进入函数或方法内运行. 当我们不想看函数内部的运行过程时,点击跳出函 ...

  8. Go语言实现:【剑指offer】数组中只出现一次的数字

    该题目来源于牛客网<剑指offer>专题. 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 正常能想到哈希表来处理,但此题考查的是异或的知识, ...

  9. 安装Mysql时提示尚未安装Python 解决方案

    我明明安装了python,结果在安装mysql是却提示没有安装python. 原因,没有将python添加到path中. 解决方法:卸载python,然后重装python,在安装界面中勾选将path添 ...

  10. html标签学习入门 随笔

    Html学习入门    随笔1: HTML 标题 HTML 标题(Heading)是通过 <h1> - <h6> 等标签进行定义的. 标题仅用于标题文本  不应该被使用在加粗字 ...