【16届蓝桥杯寒假刷题营】第2期DAY2

1.快快变大 - 蓝桥云课

问题描述

小蓝非常喜欢数字,特别是大的数,但是对于超过一定界限的数,小蓝则会非常讨厌他,现在给定你 n 个数,以及一个上界 k,定义小蓝的喜爱值为选出的所有数的和,求小蓝的最大喜爱值为多少?

输入格式

第一行给定两个整数 n,k 表示共有 n 个数字以及上界 k。

第二行给定 n 个数,表示数的大小。

输出格式

输出一个整数表示小蓝的最大喜爱值。

输入案例

复制代码
5 10
1 2 3 4 5

样例输出

复制代码
16

评测数据规模

对于 100% 的评测数据:1≤n≤44,0≤k≤1e9。

思路:

代码如下:

爆搜:

复制代码
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
ll n,k;
const ll N = 1e3+10;
ll arr[N];
ll ans = -1e9;
void dfs(ll x, ll sum)
{
	if(sum > k)
	return;
	if(x > n)
	{
		if(sum <= k)
		{
			ans = max(ans,sum);
		}
		return;
	}
	dfs(x+1,sum+arr[x]);
	dfs(x+1,sum);
}
int main(void)
{
	cin >> n >> k;
	for(ll i = 1 ; i <= n ; i++)
	cin >> arr[i];
 	dfs(1,0);
	cout << ans;
	return 0;
}

二分:

相关推荐
veejaLiu28 分钟前
LeetCode 30.串联所有单词的子串
java·学习·算法·leetcode·职场和发展·刷题
Echo木2 小时前
DeepSeek-R1学习
人工智能·学习·算法
残血小法师4 小时前
C++ 学习笔记(三)—— 入门+类和对象
c++·笔记·学习
WispX8884 小时前
【JVM】GC 常见问题
java·jvm·算法
安忘6 小时前
LeetCode-274.H 指数
算法·leetcode·职场和发展
xxxmmc6 小时前
Leetcode 160 Intersection of Two Linked Lists
算法·leetcode·双指针
VincentStory7 小时前
分享一个项目中遇到的一个算法题
android·算法
Zhuai-行淮9 小时前
施磊老师高级c++(一)
开发语言·c++
ylfhpy9 小时前
Java面试黄金宝典1
java·开发语言·算法·面试·职场和发展
这个懒人9 小时前
SB重删算法详解:原理、架构与实现
c++·算法·哈希算法