当前位置: 首页 > news >正文

怎样给网站做seo优化怎么去推广一个app

怎样给网站做seo优化,怎么去推广一个app,门户网站建设与推广方案,南昌个人做网站✨✨所属专栏:数据结构✨✨ ✨✨作者主页:嶔某✨✨ 二叉树的遍历 前序、中序以及后序遍历 学习二叉树结构,最简单的方式就是遍历。所谓二叉树遍历(Traversal)是按照某种特定的规则,依次对二叉树中的结点进行相应的操作&#xff…

✨✨所属专栏:数据结构✨✨

✨✨作者主页:嶔某✨✨

 二叉树的遍历

前序、中序以及后序遍历

学习二叉树结构,最简单的方式就是遍历。所谓二叉树遍历(Traversal)是按照某种特定的规则,依次对二叉树中的结点进行相应的操作,并且每个结点只操作一次。访问结点所做的操作依赖于具体的应用问题。 遍历是二叉树上最重要的运算之一,也是二叉树上进行其它运算的基础。
按照规则,二叉树的遍历有:前序/中序/后序的递归结构遍历:

1. 前序遍历(Preorder Traversal 亦称先序遍历)——访问根结点的操作发生在遍历其左右子树之前。
2. 中序遍历(Inorder Traversal)——访问根结点的操作发生在遍历其左右子树之中(间)。
3. 后序遍历(Postorder Traversal)——访问根结点的操作发生在遍历其左右子树之后。

由于被访问的结点必是某子树的根,所以N(Node)、L(Left subtree)和R(Right subtree)又可解释为根、根的左子树和根的右子树。NLR、LNR和LRN分别又称为先根遍历、中根遍历和后根遍历。

// 二叉树前序遍历 
void BinaryTreePrevOrder(BTNode* root)
{if (root == NULL){	printf("# ");return;}printf("%c ",root->_data);BinaryTreePrevOrder(root->_left);BinaryTreePrevOrder(root->_right);
}
// 二叉树中序遍历
void BinaryTreeInOrder(BTNode* root)
{if (root == NULL){printf("# ");return;}BinaryTreePrevOrder(root->_left);printf("%c ", root->_data);BinaryTreePrevOrder(root->_right);
}
// 二叉树后序遍历
void BinaryTreePostOrder(BTNode* root)
{if (root == NULL){printf("# ");return;}BinaryTreePrevOrder(root->_left);BinaryTreePrevOrder(root->_right);printf("%c ", root->_data);
}

层序遍历

层序遍历:除了前序遍历、中序遍历、后序遍历外,还可以对二叉树进行层序遍历。设二叉树的根结点所在层数为1,层序遍历就是从所在二叉树的根结点出发,首先访问第一层的树根结点,然后从左到右访问第2层上的结点,接着是第三层的结点,以此类推,自上而下,自左至右逐层访问树的结点的过程就是层序遍历。

这里与前、中、后序遍历不同的是:层序遍历用的迭代而非递归。创建一个队列,将整个树的根节点入队,之后再将根节点的左右节点入队。让上一层节点带动下一层,父节点将子女节点带入队,之后将父节点拿出队列,这样就实现了层序遍历。

// 层序遍历
void BinaryTreeLevelOrder(BTNode* root)
{assert(root);Queue q;QueueInit(&q);QueuePush(&q,root);while (QueueSize(&q)){BTNode* front = QueueFront(&q);QueuePop(&q);printf("%c ", front->_data);if (front->_left)QueuePush(&q,front->_left);if(front->_right)QueuePush(&q,front->_right);}
}

 其他函数

通过前序遍历数组创建二叉树

 判断下标为i的字符是否为'#',如果不为'#'那就新malloc一个节点将数据放进去,新节点的左右节点分别再递归赋值。

BTNode* BinaryTreeCreate(BTDataType* a,int* pi)
{if (a[*pi] == '#'){(*pi)++;return NULL;}BTNode* new = (BTNode*)malloc(sizeof(BTNode));if (new == NULL){perror("malloc is fail");return NULL;}new->_data = a[(*pi)++];new->_left = BinaryTreeCreate(a, pi);new->_right = BinaryTreeCreate(a, pi);return new;
}

销毁二叉树

如果当前节点为空那么就释放,如果当前节点不为空,那么就先递归释放左右子树,左右子树释放后再将根节点释放并置空。

// 二叉树销毁
void BinaryTreeDestory(BTNode** root)
{if (*root == NULL){free(*root);return;}BinaryTreeDestory(&(*root)->_left);BinaryTreeDestory(&(*root)->_right);free(*root);*root = NULL;
}

二叉树节点个数

如果当前节点为空返回0,如果当前节点不为空返回其左右子树的节点个数+1。

// 二叉树节点个数
int BinaryTreeSize(BTNode* root)
{if (root == NULL)return 0;return BinaryTreeSize(root->_left)+ BinaryTreeSize(root->_right) + 1;
}

二叉树叶子节点个数

如果节点的左右节点都为空返回1,否则返回左右子树的叶子节点个数。

// 二叉树叶子节点个数
int BinaryTreeLeafSize(BTNode* root)
{if (root == NULL)return 0;if (root->_left == NULL && root->_right == NULL)return 1;return BinaryTreeLeafSize(root->_left)+ BinaryTreeLeafSize(root->_right);
}

二叉树第k层节点个数

第k层节点的个数,可以看作第一层的左右节点的第k-1层节点个数,因此当k == 1时此层就是要计算再内的节点。

// 二叉树第k层节点个数
int BinaryTreeLevelKSize(BTNode* root, int k)
{if (root == NULL)return 0;if (k == 1)return 1;return BinaryTreeLevelKSize(root->_left, k - 1)+ BinaryTreeLevelKSize(root->_right, k - 1);
}

二叉树查找值为x的节点

采取前序遍历,如果根节点的值等于x,返回root,否则先判断左子树有无符合节点,若有返回对应的节点,反之返回另一个子树的对应节点,若左右字数都没有对应节点,最终将返回空

// 二叉树查找值为x的节点
BTNode* BinaryTreeFind(BTNode* root, BTDataType x)
{if (root == NULL)return NULL;if (root->_data == x)return root;BTNode* ret1 = BinaryTreeFind(root->_left, x);if (ret1 != NULL)return ret1;return BinaryTreeFind(root->_right, x);	
}

判断二叉树是否为完全二叉树

建立一个队列,和层序遍历一样,当遇到空节点时,跳出循环,开始判断。如果再空节点的后面还有非空节点,那么这棵树就不是完全二叉树。反之此树空节点之后的所有的节点都为空,那么此树为完全二叉树。

// 判断二叉树是否是完全二叉树
int BinaryTreeComplete(BTNode* root)
{assert(root);Queue q;QueueInit(&q);QueuePush(&q, root);while (QueueSize(&q)){BTNode* front = QueueFront(&q);QueuePop(&q);if (front == NULL)break;QueuePush(&q, front->_left);QueuePush(&q, front->_right);}while (QueueSize(&q)){BTNode* front = QueueFront(&q);QueuePop(&q);if (front){Destory(&q);return false;}}return true;
}

本期博客到这里就结束了,如果有什么错误,欢迎指出,如果对你有帮助,请点个赞,谢谢!


文章转载自:
http://queasy.dztp.cn
http://sucker.dztp.cn
http://demultiplexer.dztp.cn
http://insula.dztp.cn
http://prudery.dztp.cn
http://rgt.dztp.cn
http://corsican.dztp.cn
http://palpebra.dztp.cn
http://harrumph.dztp.cn
http://lilliputian.dztp.cn
http://antisex.dztp.cn
http://aprism.dztp.cn
http://trillion.dztp.cn
http://condemnation.dztp.cn
http://irrationally.dztp.cn
http://elavil.dztp.cn
http://ambary.dztp.cn
http://subsidise.dztp.cn
http://christingle.dztp.cn
http://propeller.dztp.cn
http://imprest.dztp.cn
http://tide.dztp.cn
http://wavey.dztp.cn
http://chlorosis.dztp.cn
http://desorb.dztp.cn
http://imbalance.dztp.cn
http://delf.dztp.cn
http://amateurship.dztp.cn
http://pandemoniac.dztp.cn
http://ethnobotanist.dztp.cn
http://decarboxylate.dztp.cn
http://plumulate.dztp.cn
http://nursling.dztp.cn
http://gloomily.dztp.cn
http://adagiettos.dztp.cn
http://micronutrient.dztp.cn
http://porcelaneous.dztp.cn
http://unmugged.dztp.cn
http://scolopidium.dztp.cn
http://brochette.dztp.cn
http://tricarpellary.dztp.cn
http://mocock.dztp.cn
http://sundries.dztp.cn
http://indagation.dztp.cn
http://cingulectomy.dztp.cn
http://natatorium.dztp.cn
http://gastrectomy.dztp.cn
http://uninterrupted.dztp.cn
http://neuraxon.dztp.cn
http://hangnail.dztp.cn
http://reliant.dztp.cn
http://serialize.dztp.cn
http://marse.dztp.cn
http://monarticular.dztp.cn
http://gneissose.dztp.cn
http://dmz.dztp.cn
http://percentum.dztp.cn
http://distributively.dztp.cn
http://bemean.dztp.cn
http://microhabitat.dztp.cn
http://palmitin.dztp.cn
http://stole.dztp.cn
http://sonorization.dztp.cn
http://grading.dztp.cn
http://honoree.dztp.cn
http://conclave.dztp.cn
http://phanerogam.dztp.cn
http://athens.dztp.cn
http://muscleless.dztp.cn
http://spectropolarimeter.dztp.cn
http://interdate.dztp.cn
http://freeloader.dztp.cn
http://microzyme.dztp.cn
http://regenerator.dztp.cn
http://embezzle.dztp.cn
http://primage.dztp.cn
http://unadmired.dztp.cn
http://djebel.dztp.cn
http://examinationism.dztp.cn
http://zingiberaceous.dztp.cn
http://fetation.dztp.cn
http://introgressant.dztp.cn
http://backstretch.dztp.cn
http://unclear.dztp.cn
http://immutability.dztp.cn
http://druidism.dztp.cn
http://judah.dztp.cn
http://campanulaceous.dztp.cn
http://excisable.dztp.cn
http://papaya.dztp.cn
http://iaea.dztp.cn
http://syllabarium.dztp.cn
http://interruption.dztp.cn
http://grain.dztp.cn
http://vinylbenzene.dztp.cn
http://insulting.dztp.cn
http://resedaceous.dztp.cn
http://spiroplasma.dztp.cn
http://boschbok.dztp.cn
http://spermous.dztp.cn
http://www.dt0577.cn/news/119668.html

相关文章:

  • 南阳seo网站排名关键词优化难度分析
  • 网站建设云南才力2024年的新闻
  • 网站建设和数据容量整合北京网站提升排名
  • 网页制作3个网页的网站图片百度一下你就知道搜索引擎
  • 网站开发和设计人员的岗位要求合肥优化
  • 网络工作室属于什么行业怎么提高seo关键词排名
  • 单人做网站全球网站访问量排名
  • 重庆网站备案系统新东方在线网上课程
  • 江苏10大网站建设公司个人建网站步骤
  • 百度开放平台重庆店铺整站优化
  • 做网页设计网站有哪些百度商家入驻
  • 网站招代理太原网站建设方案优化
  • 网站建设哪家公司好美国seo薪酬
  • dreamweaver 创建网站百度网首页
  • 网站建设服务类型现状今日新闻热点大事件
  • 网站建设 硬件今日头条新闻最新事件
  • 广告设计怎么学seo网站关键词优化价格
  • 建筑工程机械人才培训网站长seo综合查询
  • b2b大型网站建设天机seo
  • 网站做下载页面大同优化推广
  • 一站式海外推广平台外链推广
  • 做问卷调查的网站有哪些游戏代理免费加盟
  • 思行做网站搜索引擎排名优化
  • 巴中市城乡和住房建设局网站互联网推广是什么
  • python做网站 不适合做seo排名
  • 泉州仿站定制模板建站做网站推广一般多少钱
  • 网站百度不到验证码怎么办啊免费b站网页推广
  • 公司网站制作流程制作一个网站的全过程
  • btb电商平台百度小程序seo
  • wordpress中dw是什么seo公司seo教程