【蓝桥杯基础算法】dfs(上)组合数,全排列

news/2024/7/20 21:23:31 标签: 算法, 蓝桥杯, 深度优先, c++

    刚接触算法,有没有被递归又循环的dfs吓到?没关系,几个例题就可以彻底掌握!

1.全排列 

 1-n的全排列,如输入3,按顺序对1-3进行排列

//枚举
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int N=10;
int n;
bool st[N];//true选过 ,false是没选过 
int arr[N];//存的是答案  
void dfs(int x)
{
	if(x>n)
	{for(int i=1;i<=n;i++)
	{
		printf("%5d",arr[i]);//长宽5
	}
	printf("\n");
	return ;
	}
	for(int i=1;i<=n;i++)
	{
		if(!st[i])
		{
			st[i]=true;
			arr[x]=i;
			dfs(x+1);
			st[i]=false;
			arr[x]=0;
		}
	}
}
int main()
{
	scanf("%d",&n);
	dfs(1);
	
	return 0;
}

2.组合数 

题目: 

 

答案:

//选数
//剪枝 
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int N=30;
int k,n;
int q[N];
int arr[N];
int res=0;

bool is_prim(int sum)
{
	if(sum<2)return false;
	for(int i=2;i<=sum/i;i++)
	{
		if(sum%i==0)return false;
	}
	return true;
}
//求组合数,x表示当前到了哪个位置
//start表示从几开始枚举 
void dfs(int x,int start)
{
	if(((x-1)+n-start+1)<k)
	{
		return ;
	}
	if(x>k){
		int sum=0
		for(int i=1;i<=k;i++)
		{
			sum+=arr[i];
		}
		if(is_prim(sum))//是素数+1 
		{
			res++;
		}
	}
	for(int i=start;i<=n;i++)
	{
		arr[x]=q[i];
		dfs(x+1,i+1);//继续向下,深度优先 
		arr[x]=0;//恢复现场 
	}
}

int main()
{
	scanf("%d %d",&n,&k);
	dfs(1,1);
	printf("%d\n",res);
	return 0;
}

 

 

 


http://www.niftyadmin.cn/n/5413810.html

相关文章

【智能家居入门1之环境信息监测】(STM32、ONENET云平台、微信小程序、HTTP协议)

作为入门本篇只实现微信小程序接收下位机上传的数据&#xff0c;之后会持续发布如下项目&#xff1a;①可以实现微信小程序控制下位机动作&#xff0c;真正意义上的智能家居&#xff1b;②将网络通讯协议换成MQTT协议再实现上述功能&#xff0c;此时的服务器也不再是ONENET&…

react hook: useLayoutEffect

useLayoutEffect 可能会影响性能。尽可能使用 useEffect。&#xff08;由于 useLayoutEffect 它会在浏览器更新布局之前同步执行。 在执行时会阻塞浏览器更新&#xff0c;因此需要谨慎使用&#xff09; useLayoutEffect 是 useEffect 的一个版本&#xff0c;在浏览器重新绘制屏…

代码随想录算法训练营第五十四天| 392.判断子序列、115.不同的子序列

代码随想录算法训练营第五十四天| 392.判断子序列、115.不同的子序列 392.判断子序列115.不同的子序列 392.判断子序列 题目链接 文章讲解 class Solution { public:bool isSubsequence(string s, string t) {vector<vector<int>> dp(s.size() 1, vector<int&g…

【论文笔记】An Effective Adversarial Attack on Person Re-Identification ...

原文标题&#xff08;文章标题处有字数限制&#xff09;&#xff1a; 《An Effective Adversarial Attack on Person Re-Identification in Video Surveillance via Dispersion Reduction》 Abstract 通过减少神经网络内部特征图的分散性攻击reid模型。 erbloo/Dispersion_r…

微信小程序简单输入框界面(实现选择标签功能)

微信小程序简单输入框界面&#xff0c;实现选择标签功能、输入框字数计数的简单界面功能。 1、js代码&#xff1a; Page({/*** 页面的初始数据*/data: {count: 500,labelList: [{text: 开心,checked: true}, {text: 难受想哭,checked: true},{text: 快乐,checked: false}, {te…

基于 JavaAgent 代理技术实现 class 字节码插桩(bytebuddy)

先描述一个场景&#xff0c;生产有一个正在运行的java项目&#xff0c;以某 springboot-service.jar 为例&#xff0c;项目发布后发现了某个http接口响应较慢&#xff0c;此时你希望定位这个http接口执行过程中依次调用的几个主要方法的分别执行耗时&#xff0c;用来作为进一步…

JVM(内存区域划分)

JVM JVM - Java虚拟机 我们编写的 Java 程序, 是不能够被 OS 直接识别的 JVM 充当翻译官的角色, 负责把我们写的的 Java 程序 ,翻译给 OS “听”, 让 OS 能够识别我们所写的 Java 代码 JVM 内存区域划分 JVM 是一个应用程序, 在启动的时候, 会从 操作系统 申请到一整块很大的内…

在centos7系统中如何给docker配置代理

一、需求场景 生产环境私有云中&#xff0c;通常一个集群的机器中只有几台机器可以直接访问公网&#xff0c;其他机器需要通过代理的方式从能访问公网的机器出去&#xff0c;在已经做了如下配置之后&#xff0c;使用docker pull命令已经报错超时timeout&#xff0c;这时可以尝…