洛谷 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;
 } 
相关推荐
生信与遗传解读21 分钟前
XGBoost算法在自定义数据集中预测疾病风险
人工智能·python·算法·数据分析
这辈子秃头是不可能的27 分钟前
OpenGL利用DDA算法绘制图形,并增加鼠标键盘交互
算法·计算机外设·交互
灵哎惹,凌沃敏1 小时前
华为C语言编程规范总结
c语言·开发语言
BingLin-Liu2 小时前
蓝桥杯备考:数据结构之栈 和 stack
数据结构
范纹杉想快点毕业3 小时前
XML通过HTTP POST 请求发送到指定的 API 地址,进行数据回传
xml·c语言·开发语言·数据结构·c++·python·c#
星迹日3 小时前
数据结构:LinkedList与链表—无头单向链表(一)
java·数据结构·经验分享·笔记·链表·单向链表
float_六七3 小时前
C/C++头文件locale
c语言·开发语言·c++
shdbdndj3 小时前
C语言:枚举类型
c语言
小胖学前端3 小时前
如何运行一个Ink节点:从安装到监控的全方位指南
算法
OTWOL3 小时前
栈与队列OJ题精选,数据结构的实践应用
数据结构