题目 https://www.luogu.org/problemnew/show/P1036

思路

搜索,使用递归实现dfs,所有数字遍历一遍,当取遍所有数组的index(扫了一遍,并非一定是选取了),判断是否取了要求个数的输入和是否是素数

AC代码

  1. #include<cstdio>
  2. #include<cmath>
  3. using namespace std;
  4. int in[22];
  5. int ans=0;
  6. int n, k;
  7. bool isprim(int num) {
  8. for (int i = 2; i <= sqrt(num); i++)
  9. if (num % i == 0)
  10. return false;
  11. return true;
  12. }
  13. //传递当前选择的数的下标,传递已选择数的个数,以选择的数的总和
  14. void dfs(int cur, int cnt, int num) {
  15. if (cur == n-1) {
  16. if (cnt==k&&isprim(num)) {
  17. ans++;
  18. }
  19. return;
  20. }
  21. dfs(cur+1,cnt,num);//不拿
  22. dfs(cur+1,cnt+1,num+in[cur+1]);//拿
  23. }
  24. int main() {
  25. // freopen("E:\\下载\\testdata (1).in","r",stdin);
  26. scanf("%d%d", &n, &k);
  27. for (int i = 0; i <= n-1; i++)
  28. scanf("%d", &in[i]);
  29. dfs(-1, 0, 0);
  30. printf("%d", ans);
  31. return 0;
  32. }

稍微优化

  1. #include<cstdio>
  2. #include<cmath>
  3. using namespace std;
  4. int in[22];
  5. int ans=0;
  6. int n, k;
  7. bool isprim(int num) {
  8. for (int i = 2; i <= sqrt(num); i++)
  9. if (num % i == 0)
  10. return false;
  11. return true;
  12. }
  13. //传递当前选择的数的下标,传递已选择数的个数,以选择的数的总和
  14. void dfs(int cur, int cnt, int num) {
  15. if (cur == n) {
  16. if (cnt==k&&isprim(num)) {
  17. ans++;
  18. }
  19. return;
  20. }
  21. //第一个结点从这开始
  22. if((k-cnt)>(n-cur))//剩下的不足以满足cnt=k时
  23. return;
  24. dfs(cur+1,cnt,num);//不拿
  25. dfs(cur+1,cnt+1,num+in[cur+1]);//拿
  26. }
  27. int main() {
  28. // freopen("E:\\下载\\testdata (1).in","r",stdin);
  29. scanf("%d%d", &n, &k);
  30. for (int i = 1; i <= n; i++)
  31. scanf("%d", &in[i]);
  32. dfs(0, 0, 0);
  33. printf("%d", ans);
  34. return 0;
  35. }

我的收获

dfs()参数可以为index,数量,聚合函数这个样子

P1036 选数(DFS)的更多相关文章

  1. 洛谷P1036.选数(DFS)

    题目描述 已知 n个整数 x1,x2,-,xn,以及11个整数k(k<n).从n个整数中任选k个整数相加,可分别得到一系列的和.例如当n=4,k=3,4个整数分别为3,7,12,19时,可得全部 ...

  2. luogu P1036 选数 x

    P1036 选数 题目描述 已知 n 个整数 x1,x2,…,xn,以及一个整数 k(k<n).从 n 个整数中任选 k 个整数相加,可分别得到一系列的和.例如当 n=4,k=3,4 个整数分别 ...

  3. NOIP 2002提高组 选数 dfs/暴力

    1008 选数 2002年NOIP全国联赛普及组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知 n 个整数 x1,x2,…, ...

  4. 【搜索】【入门】洛谷P1036 选数

    题目描述 已知 n个整数x1​,x2​,…,xn​,以及1个整数k(k<n).从nn个整数中任选kk个整数相加,可分别得到一系列的和. 例如当n=4,k=3,4个整数分别为3,7,12,19时, ...

  5. (递归)P1036 选数

    #include<stdio.h>#include<math.h>int x[20],n,k,i; //判断是否质数 int isprime(int n){    for(i= ...

  6. 洛谷 P1036 选数【背包型DFS/选or不选】

    题目描述 已知 n 个整数 x1,x2,…,xn,以及一个整数 k(k<n).从 n 个整数中任选 k 个整数相加,可分别得到一系列的和.例如当 n=4,k=3,4 个整数分别为 3,7,12, ...

  7. 洛谷P1036 选数 题解 简单搜索/简单状态压缩枚举

    题目链接:https://www.luogu.com.cn/problem/P1036 题目描述 已知 \(n\) 个整数 \(x_1,x_2,-,x_n\) ,以及 \(1\) 个整数 \(k(k& ...

  8. 洛谷 P1036 选数

    嗯.... 这种类型的题在新手村出现还是比较正常的, 但是不知道为什么它的分类竟然是过程函数与递归!!!(难道这不是一个深搜题吗??? 好吧这就是一道深搜题,所以千万别被误导... 先看一下题目: 题 ...

  9. (水题)洛谷 - P1036 - 选数

    https://www.luogu.org/problemnew/show/P1036 $n$ 才20的数据量,我当时居然还在想怎么分组组合,直接 $2^{20}$ 暴力搞就行了. $x_i $太大了 ...

随机推荐

  1. rabbitmq最大连接数(Socket Descriptors)

    RabbitMQ自带了显示能够接受的最大连接数,有2种比较直观的方式:1. rabbitmqctl命令. 1 2 3 4 5 6 7 8 9 10 11 12 <span style=" ...

  2. ubuntu16.04 查看CPU是几核

    ubuntu 16.04下查看机器是cpu是几核的 几个cpu more /proc/cpuinfo |grep "physical id"|uniq|wc -l 每个cpu是几核 ...

  3. CodeForces 515C Drazil and Factorial (水题)

    题意:给出含有 n 个只有阿拉伯数字的字符串a,设定函数F(a) = 每个数字的阶乘乘积 .需要找出 x,使得F(x) = F(a),且组成 x 的数字中没有0和1.求最大的 x 为多少. 析:最大, ...

  4. vue中子组件向父组件传值

    1.子组件$emit()触发,父组件$on()监听 子组件:<template> <div class="hello"> <button v-on:c ...

  5. bzoj4987: Tree(树形dp)

    Description 从前有棵树. 找出K个点A1,A2,…,Ak. 使得∑dis(AiAi+1),(1<=i<=K-1)最小.   Input 第一行两个正整数n,k,表示数的顶点数和 ...

  6. linux下jdk环境变量配置深度分析----解决环境变量不生效的问题

    1.linux下jdk环境变量配置 是否需要配置环境变量,主要看java -version 显示的版本是否为你期望的版本 1.1 不需要配置环境变量的情况 使用java -version查看,版本显示 ...

  7. 【题解】TES-Intelligence Test

    [题解]\(TES-Intelligence\) \(Test\) 逼自己每天一道模拟题 传送:\(TES-Intelligence\) \(Test\) \([POI2010]\) \([P3500 ...

  8. ViewPager(3)用viewpager实现tabhost

    1.示例 2.代码 2.1 TabViewPagerMain.java import android.graphics.drawable.Drawable; import android.os.Bun ...

  9. 274 H-Index H指数

    给定一位研究者的论文被引用次数的数组(被引用次数是非负整数).写一个方法计算出研究者的H指数.H-index定义: “一位科学家有指数 h 是指他(她)的 N 篇论文中至多有 h 篇论文,分别被引用了 ...

  10. C#基础 函数部分

    函数:能够独立完成某项功能的模块. 函数四要素:输入.输出.函数体.函数名 函数定义: (static/public) 返回类型 函数名(参数类型 参数名,参数类型 参数名){ 函数体} 函数的调用: ...