洛谷 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;
 } 
相关推荐
昵称小白2 小时前
复杂度分析方法
算法
科研前沿2 小时前
2026 数字孪生前沿科技:全景迭代报告 —— 镜像视界生成式孪生(Generative DT)技术白皮书
大数据·人工智能·科技·算法·音视频·空间计算
leo__5203 小时前
IEC 104 协议 C 语言实现
c语言·数据库
学涯乐码堂主4 小时前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
切糕师学AI4 小时前
环形缓冲区(Ring Buffer / Circular Buffer)详解:原理、优势、应用与高性能实现
数据结构·环形缓冲区
Tutankaaa4 小时前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073215 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
啧不应该啊5 小时前
Day1 Python 与 C 的类型区别
c语言·开发语言
cen__y5 小时前
Linux07(信号01)
linux·运维·服务器·c语言·开发语言
aini_lovee7 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab