C言語によるツリーの深さの算出方法

1121 ワード

本稿では,計算ツリーの深さをC言語で実現する方法を例示する.アルゴリズム設計でよく使われるテクニックです.皆さんの参考にしてください.具体的な方法は以下の通りです.

/* 
* Copyright (c) 2011 alexingcool. All Rights Reserved. 
*/ 
#include 

using namespace std;

struct Node {
 Node(int i = 0, Node *l = NULL, Node *r = NULL) : data(i), left(l), right(r) {}

 int data;
 Node *left;
 Node *right;
};

Node* Construct() {
 Node *node4 = new Node(7, NULL, new Node(3));
 Node *node3 = new Node(4);
 Node *node2 = new Node(12);
 Node *node1 = new Node(5, node3, node4);
 Node *root = new Node(10, node1, node2);
 return root;
}

int GetTreeHeight(Node *root) {
 if(root == NULL)
 return 0;
 return max(GetTreeHeight(root->left) + 1, GetTreeHeight(root->right) + 1);
}

void main() {
 Node *root = Construct();
 int height = GetTreeHeight(root);
 cout << "tree height is: " << height << endl;
}


ここで述べた例は皆さんのCプログラムアルゴリズム設計の学習に役立つことを望んでいます.