zl程序教程

您现在的位置是:首页 >  其他

当前栏目

树形结构的3中搜索方式示例分享

搜索 方式 示例 分享 结构 树形
2023-06-13 09:15:18 时间

复制代码代码如下:


/**
树的3中常见搜索方式
1.二叉树方式(每一层只有0和1)
2.满m叉树(每一层都有0到m-1)
3.子集树,也称为全排列树
*/
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<string>

usingnamespacestd;

constintM=20;

intn,m;
intans[M];
//二叉树
voiddfs_two(intcur){
 if(cur==n){
  for(inti=0;i<n;i++){
   cout<<ans[i]<<"";
  }
  cout<<endl;
  return;
 }
 ans[cur]=1;
 dfs_two(cur+1);
 ans[cur]=0;
 dfs_two(cur+1);
}

//m叉树
voiddfs_m(intcur){
 if(cur==n){
  for(inti=0;i<n;i++){
   cout<<ans[i]<<"";
  }
  cout<<endl;
  return;
 }
 for(inti=0;i<n;i++){
  ans[cur]=i;
  dfs_m(cur+1);
 }
}
boolvis[M];
//子集树
voiddfs_sub(intcur){
 if(cur==n){
  for(inti=0;i<n;i++){
   cout<<ans[i]<<"";
  }
  cout<<endl;
  return;
 }
 for(inti=0;i<n;i++){
  if(false==vis[i]){
   vis[i]=true;
   ans[cur]=i;
   dfs_sub(cur+1);
   vis[i]=false;
  }
 }
}

intmain(){

 n=5;
 memset(ans,-1,sizeof(ans));
 memset(vis,false,sizeof(vis));
 dfs_two(0);//二叉树搜索
 dfs_m(0);//满m叉树搜索
 dfs_sub(0);//子集树搜索
 return0;
}