洛谷 P1036 [NOIP2002 普及组] 选数 C语言

题目:
https://www.luogu.com.cn/problem/P1036

题目描述

已知 nn 个整数 x1,x2,⋯ ,xn,以及 1 个整数 k(k<n)。从 n 个整数中任选 k 个整数相加,可分别得到一系列的和。例如当 n=4,k=3,4 个整数分别为 3,7,12,19 时,可得全部的组合与它们的和为:

3+7+12=22

3+7+19=29

7+12+19=38

3+12+19=34

现在,要求你计算出和为素数共有多少种。

例如上例,只有一种的和为素数:3+7+19=29。

输入格式

第一行两个空格隔开的整数 n,k(1≤n≤20,k<n)。

第二行 n 个整数,分别为 x1,x2,⋯ ,xn​(1≤xi≤5×10的6次方)。

思路:就是暴力枚举,最后加一个是否是素数的判断

代码如下:

复制代码
#include<iostream>
using namespace std;
typedef long long ll;
ll n,k;
ll num[25];
ll arr[25];
ll res = 0;
bool is_prime(ll m)
{
	for(ll i = 2 ; i * i <= m ; i++)
	{
		if(m % i == 0)
		return false;
	}
	return true;
}
void dfs(ll x,ll sum,ll start)
{
	if(x > k)
	{
		if(is_prime(sum))
		{
			res++;
		}
		return;
	 }
	 
	 for(ll i = start ; i <= n ;i++)
	 {
	 	arr[x] = num[i];
	 	dfs(x+1,sum + arr[x],i+1);
	 	arr[x] = 0;
	  } 
}
int main()
{
	cin >> n >> k;
	for(ll i = 1 ; i <= n ; i++)
	cin >> num[i];
	dfs(1,0,1);
	cout << res <<endl; 
	return 0;
 } 
相关推荐
wuweijianlove4 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
_dindong4 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志4 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
沫璃染墨4 小时前
C++ string 从入门到精通:构造、迭代器、容量接口全解析
c语言·开发语言·c++
黎阳之光5 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_115 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg5 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒5 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾5 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio