【1115】Counting Nodes in a BST (30分)【BST建树 DFS】

简介: 【1115】Counting Nodes in a BST (30分)【BST建树 DFS】【1115】Counting Nodes in a BST (30分)【BST建树 DFS】
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include<algorithm>  
#include<map>
#include<vector>
#include<queue> 
using namespace std;  
/*链表存储---递归建BST---DFS,传入的参数为结点和depth*/
/*若当前结点为NULL则更新maxdepth并return,数组sum存每层对应结点数*/
struct node{
  int data;
  struct node *left,*right;
};
void insert(node* &root,int data){
  if(root == NULL){//空树,说明查找失败,也即插入位置
    root=new node; //申请一个node结构体地址空间
    root->data=data;
    root->left=root->right=NULL;//初始无左右孩子
    return;
  }//一定要注意下面这个if是小于等于!!有等于情况
  if(data<=root->data) insert(root->left,data);//插在左子树
  else insert(root->right,data);//插在右子树
}
vector<int> num(1000);
int maxdepth=-1;
void dfs(node *root,int depth){
  if(root ==NULL){
    maxdepth=max(depth,maxdepth);
    return;
  }
  num[depth]++;//每访问一个结点就在这对应层的节点数加1
  dfs(root->left,depth+1);
  dfs(root->right,depth+1);
}
int main(){   
  int n,data;
  node* root=NULL;//定义头结点
  scanf("%d",&n);//结点个数
  for(int i=0;i<n;i++){
    scanf("%d",&data);
    insert(root,data);//将data插入树中
  }
  dfs(root,0);
  printf("%d + %d = %d",num[maxdepth-1] , num[maxdepth-2] , num[maxdepth-1]+num[maxdepth-2]);
  system("pause");
    return 0;   
}
相关文章
|
7月前
|
人工智能 算法 Java
深度优先搜索(Depth-First Search,DFS)是一种用于遍历或搜索树或图的算法。
深度优先搜索(Depth-First Search,DFS)是一种用于遍历或搜索树或图的算法。
LeetCode 102. 二叉树的层序遍历 Binary Tree Level Order Traversal
LeetCode 102. 二叉树的层序遍历 Binary Tree Level Order Traversal
【1094】The Largest Generation (树DFS-水题)
基础题。 这类题也是直接DFS,不是像上次的【1079】&【1090】供应树DFS一样是到了叶子结点就进行“更新/结算”类型,这题直接利用DFS统计每层的结点个数即可。
104 0
|
存储
题解报告:POJ 2386--Lake Counting(BFS+DFS)
给你一副图n行m列,其中’W’代表池塘,’.'代表土地,问现在这幅图中有多少个池塘,如果一个池塘的八个方向上如果有池塘,则只算一个,类似于连通块,求有多少个连通块。
131 0
1004. Counting Leaves (30) 树的dfs
#include #include #include using namespace std; //大意:统计每一层叶子结点的个数 并输出 //根节点id固定为01 //思路:树的模拟套路 vector v[100]...
885 0