课后作业-2025年12月07号作业

**题目:**P10448 组合型枚举

网址: https://www.luogu.com.cn/problem/P10448

**思路:**我们定义一个dfs函数,step代表要选取第step个数,last代表上一个选取的数

**知识点:**dfs

代码:

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long 
using namespace std;
const int maxn=2e5+100;
ll n,m;
int vis[maxn],a[maxn];
void dfs(int step,int last)
{
	if(step==m+1)
	{
		for(int i=1;i<=m;i++)
		cout<<a[i]<<" ";
		cout<<'\n';
		return;
	}
	for(int i=last+1;i<=n;i++)
	{
		if(!vis[i])
		{
			a[step]=i;
			vis[i]=true;
			dfs(step+1,i);
			vis[i]=false;
		}
	}
}
int main(){
	
    ios::sync_with_stdio(false);
	cin.tie(0);cout.tie(0); 
	cin>>n>>m;
	dfs(1,0);
	return 0;
}

**题目:**B3622 枚举子集(递归实现指数型枚举)

网址: https://www.luogu.com.cn/problem/B3622

**思路:**对于每一个人,我们都有两种选择方法,选或者不选。

**知识点:**dfs

代码:

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define pii pair<int,int>
#define fi first
#define se second 
using namespace std;
const int maxn=1e3+100;
ll n,m;
int a[110];
int vis[110][110];
int dx[]={0,0,1,-1};
int dy[]={1,-1,0,0};
void dfs(int step)
{
	if(step>n)
	{
		for(int i=1;i<=n;i++)
		{
			if(a[i])
			cout<<"Y";
			else cout<<"N";
		}
		cout<<'\n';
		return;
	}
	a[step]=0;
	dfs(step+1);
	a[step]=1;
	dfs(step+1);
}
int main(){
	
    ios::sync_with_stdio(false);
	cin.tie(0);cout.tie(0); 
	cin>>n;
	dfs(1);
	return 0;
}

**题目:**B3623 枚举排列(递归实现排列型枚举)

网址: https://www.luogu.com.cn/problem/B3623

**思路:**我们定义一个dfs函数,step代表第step个数选取哪一个

**知识点:**dfs

代码:

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define pii pair<int,int>
#define fi first
#define se second 
using namespace std;
const int maxn=1e3+100;
ll n,k;
int a[110];
int vis[110];
int dx[]={0,0,1,-1};
int dy[]={1,-1,0,0};
void dfs(int step)
{
	if(step>k)
	{
		for(int i=1;i<=k;i++)
		{
			cout<<a[i]<<" ";
		}
		cout<<'\n';
		return;
	}
	for(int i=1;i<=n;i++)
	{
		if(!vis[i])
		{
			vis[i]=1;
			a[step]=i;
			dfs(step+1);
			vis[i]=0;
		}
	}
}
int main(){
	
    ios::sync_with_stdio(false);
	cin.tie(0);cout.tie(0); 
	cin>>n>>k;
	dfs(1);
	return 0;
}
相关推荐
努力也学不会java14 分钟前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎30 分钟前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan1 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
顶点多余1 小时前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
汉克老师1 小时前
GESP2026年3月认证C++四级( 第二部分判断题(1-10))
c++·指针·函数重载·文件操作·数组·gesp4级·gesp四级
智者知已应修善业1 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
khddvbe2 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
C羊驼2 小时前
C语言:两天打鱼,三天晒网
c语言·经验分享·笔记·算法·青少年编程
菜菜小狗的学习笔记2 小时前
剑指Offer算法题(四)链表
数据结构·算法·链表
myloveasuka2 小时前
[Java]查找算法&排序算法
java·算法·排序算法