首页 > 其他分享 >回溯法求解n个元素的集合的幂集

回溯法求解n个元素的集合的幂集

时间:2024-01-05 16:58:58浏览次数:29  
标签:幂集 遍历 求解 int 元素 回溯 过程 Powerset

 

 

过程:

  • 树中的根节点表示幂集元素的初始状态(为空集);
  • 叶子节点表示它的终结状态中幂集ρ(A)的8个元素;
  • 第i层(i=1,2,3,...,n)层的分支节点,则表示已对集合A中前i-1个元素进行了取/舍处理的当前状态(其中左分支表示“取”,右分支表示“舍”);
  • 将上述问题求解集合的幂集转换为先序遍历这棵状态树的过程。
void Powerset(int i,int n){
	//初始调用:Powerset(1,n)
	if(i>n){
		输出幂集的其中一个元素 
	}else{
		取第i个元素
		Powerset(i+1,n);
		舍第i个元素 
		Powerset(i+1,n);
	}
}  

提示:上述的关键问题是怎么表示“取”和“舍”的过程。

疑问:为什么说求幂集元素的过程是先序遍历状态树的过程呢?

解释:首先要清楚先序遍历的过程是先根后左再右,这样的一个遍历过程;那么在该代码中怎么体现这个先序遍历的过程的呢?从上面画出的集合的幂集二叉树图,可以看到,其实就是通过“取”或者“舍”这个方法来实现的,代码中的auxset[i-1]=set[i-1]就是在进入“左子树”的过程,也就是“取”的过程;而auxset[i-1]=0,则是在进入“右子树”的过程,也就是在“舍”的过程。如果读者还是感觉有点抽象,可以在纸上模拟一下这个过程就能深有体会了。

#define maxn 10
 
//使用数组set表示集合
int set[maxn];
//使用辅助数组auxset表示取和舍的过程
int auxset[maxn];
 
void Powerset(int i,int n){
	if(i>n){
		for(int j=0;j<i-1;j++){
			printf("%d  ",auxset[j]);
		}
		printf("\n");
	}else{
		auxset[i-1]=set[i-1];
		Powerset(i+1,n);
		auxset[i-1]=0;
		Powerset(i+1,n);
	}
}

 

 

转载自:https://mydreamambitious.blog.csdn.net/?type=blog 

标签:幂集,遍历,求解,int,元素,回溯,过程,Powerset
From: https://www.cnblogs.com/FBsharl/p/17947581

相关文章

  • 算法分析-回溯算法-求解N皇后问题
    一.题目需求n皇后问题是一道比较经典的算法题。它研究的是将n个皇后放置在一个n×n的棋盘上,使皇后彼此之间不相互攻击。即任意两个皇后都不能处于同一行、同一列或同一斜线上。二.算法思想1.构建棋盘可以用一个n×n列表来表示棋盘,设皇后所在的位置为board[i],i代表行,board[......
  • c语言回溯法实现01背包问题
    w[N],p[N]中直接装的是样例,可以修改数据,别忘记修改N。#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>#include<stdlib.h>#defineN5//0-1背包,用三种算法实现//动态规划,贪心,回溯,分支限界voidOutput(intbestx[]);intConstraint(intt);floatBound(inti);voidB......
  • 算法分析-动态规划-求解0-1背包问题
    一.题目需求 使用一个体积大小为13的背包,选择一件或多件商品带走,使得所选商品总价值最大。商品列表如下: 二.算法思想1,这是一个经典的0-1背包问题它要求我们在一组物品中选择一些,每个物品只能选择一次或者不选择,目标是使得所选物品的总价值最大。这个问题在实际生活中有很......
  • 单调栈求解算法
    例题:503. 下一个更大元素II给定一个循环数组 nums ( nums[nums.length-1] 的下一个元素是 nums[0] ),返回 nums 中每个元素的 下一个更大元素 。数字 x 的 下一个更大的元素 是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一......
  • 【洛谷】P1024 [NOIP2001 提高组] 一元三次方程求解 (二分)
    题目描述见此:P1024如何求一个方程的根呢qwq首先,根是什么,函数y=f(x)有零点⇔方程f(x)=0有实数根⇔函数y=f(x)的图象与x轴有交点。回顾我们高一学过的一个定理:零点存在性定理:如果函数y=f(x)在区间[a,b]上的图象是连续不断的一条曲线,并且有f(a)·f(b)<0,那么,函数y=f(x)在区间(a,b)......
  • python动态规划求解最长回文子串
    回文是什么,回文是正着读和反着读都是一样的字符叫着回文。 如‘aba’,‘aa’,‘b’,这些都是回文classSolution:deflongestPalindrome(self,s:str)->str:n=len(s)dp=[[False]*nfor_inrange(n)]ans=""forlinrange(n):......
  • python递归求解青蛙跳台阶问题
    一只青蛙一次可以跳上1级台阶,也可以跳上2级。请问该青蛙跳上一个n级的台阶总共有多少种跳法。输入台阶数,输出一共有多少种跳法。defjump1(n):ifn==1:return1elifn==2:return2else:returnjump1(n-1)+jump1(n-2)x=eval(input())pr......
  • python回溯求解电话号码组合
    给定一个仅包含数字2-9的字符串,返回所有它能表示的字母组合。答案可以按任意顺序返回。给出数字到字母的映射如下(与电话按键相同)。注意1不对应任何字母。输入:digits="23"输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]示例2:......
  • python回溯法n皇后问题
    classSolution:defsolveNQueens(self,n:int):defgenerateBoard():board=list()foriinrange(n):row[queens[i]]="Q"board.append("".join(row))......
  • [持续更新][数据结构][算法]涵盖线性表、栈、链表、队列、图、动态规划、分治递归、回
    备考考点整理内部排序表格树的主要考点二叉树的常考紧紧抓住\(n_0=n_2+1\)\(n=n_0+n_1+n_2...n_m\)\(n=n_1+2*n_2+3*n_3...m*n_m\)+1哈夫曼树没有度为1的结点,也就是\(n_1=0\)完全二叉树常考总结最大岛屿问题(dfs模板)#include<iostream>#include<algorith......