蓝桥杯(3.1)

92. 递归实现指数型枚举

java 复制代码
import java.util.Scanner;

public class Main {
	static int N = 16;
	static int n;
	static int[] st = new int[N];	

	public static void dfs(int u) {
		if(u > n) {
			for(int i=1;i<=n;i++) {
				if(st[i] == 1)
					System.out.print(i+" ");
			}
			System.out.println();
			return ;
		}
		
		st[u] = 2;
		dfs(u+1);
		st[u] = 0;		
		
		st[u] = 1;
		dfs(u+1);
		st[u] = 0;		
	}
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		n = sc.nextInt();
		dfs(1);
	}
}

94. 递归实现排列型枚举

java 复制代码
import java.util.Scanner;

public class Main {
	static int N = 10;
	static int n;
	static int[] st = new int[N];	
	static boolean[] vis = new boolean[N];	

	public static void dfs(int u) {
		if(u > n) {
			for(int i=1;i<=n;i++) {
					System.out.print(st[i]+" ");
			}
			System.out.println();
			return ;
		}
		for(int i=1;i<=n;i++) {
			if(!vis[i]) {
				st[u] = i;
				vis[i] = true;
				dfs(u+1);
				st[u] = 0;
				vis[i] = false;
			}
		}
		
	}
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		n = sc.nextInt();
		dfs(1);
	}
}

93. 递归实现组合型枚举

java 复制代码
import java.util.Scanner;

public class Main {
	static int N = 26;
	static int n;
	static int m;
	static int[] st = new int[N];	

	public static void dfs(int u,int start) {
		if(u > m) {
				for(int i=1;i<=m;i++) {
					System.out.print(st[i]+" ");
				}
				System.out.println();
				return ;
		}
		for(int i=start;i<=n;i++) {
				st[u] = i;
				dfs(u+1,i+1);
				st[u] = 0;
			}		
	}
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		n = sc.nextInt();
		m = sc.nextInt();
		//u和start
		dfs(1,1);
	}
}
相关推荐
AI小老六5 分钟前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术44 分钟前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考15 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队18 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
_清歌2 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法