判断一个二叉树是否是二叉搜索树-创新互联
#include "stdafx.h"
#include#includeusing namespace std;
class Node {public:
Node(int i);
int k;
Node* left;
Node* right;
};
Node::Node(int i)
{k = i;
left = NULL;
right = NULL;
}
Node* newNode[15];
Node* (*CreateTree(vectorvx))[15]
{int i = 0;
for (i = 0; i< vx.size(); ++i)
{newNode[i] = new Node(vx[i]);
}
for (i = 0; i< vx.size(); ++i)
{if ((2 * i + 1)< vx.size())
{ newNode[i]->left = newNode[2 * i + 1];
}
else
{ return &newNode;
}
if ((2 * i + 2)< vx.size())
{ newNode[i]->right = newNode[2 * i + 2];
}
else
{ return &newNode;
}
}
}
void InPrint(Node* n)
{if (n == NULL)
{return;
}
InPrint(n->left);
printf("%d**", n->k);
InPrint(n->right);
}
bool ifBSTtree(Node* (*n3)[15], vectorv)
{vectorvMax;
vectorvMin;
for (int i=0;ivMax.push_back(v[i]);
vMin.push_back(v[i]);
}
for (int j=v.size()-1;j>0;j--)
{int m = (j - 1) / 2;//father
if ((j % 2 == 1)&& ((*(*n3 + m))->k)>vMax[j])//left
{ vMin[m] = vMin[j];
}
else if((j%2==0)&& ((*(*n3+m))->k) vMax[m] = vMax[j];
}
else
{ return false;
}
}
return true;
}
int main()
{//arrT n1;
Node* (*n2)[15];
n2 = NULL;
int i1[15] = {10,5,15,3,8,13,20,2,4,7,9,12,14,19,50 };
vectorv1(i1, i1 + 15);
n2 = CreateTree(v1);
//n3 = n2;
InPrint(*n2[0]);
bool b1 = ifBSTtree(n2, v1);
printf("%d",b1);
while (1);
return 0;
}
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
创新互联建站专注于嘉禾网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供嘉禾营销型网站建设,嘉禾网站制作、嘉禾网页设计、嘉禾网站官网定制、小程序开发服务,打造嘉禾网络公司原创品牌,更为您提供嘉禾网站排名全网营销落地服务。标题名称:判断一个二叉树是否是二叉搜索树-创新互联
文章转载:http://myzitong.com/article/dsosed.html