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

购买建立网站费怎么做会计凭证wordpress 快速回复

购买建立网站费怎么做会计凭证,wordpress 快速回复,wordpress媒体库远程图片,wordpress国外主题加载慢树是一种非线性的数据结构,它由节点组成,并且这些节点之间通过边连接。树的每个节点可以有一个或多个子节点,并且有一个特殊的节点叫做根节点(没有父节点)。树在计算机科学中应用广泛,尤其是在数据库索引、…

树是一种非线性的数据结构,它由节点组成,并且这些节点之间通过边连接。树的每个节点可以有一个或多个子节点,并且有一个特殊的节点叫做根节点(没有父节点)。

树在计算机科学中应用广泛,尤其是在数据库索引、编译器设计和搜索算法等方面。

树的基本知识点


节点

包含数据以及指向其子节点的引用或链接。

连接两个节点之间的关系。

根节点

树的最顶端节点,唯一没有父节点的节点。

叶子节点

没有子节点的节点。

父节点与子节点

直接相连的上下层节点间的关系。

深度

从根到某个节点的路径长度。

高度

从某节点到叶子节点的最大路径长度。树的高度是指根节点的高度。

子树

由一个节点及其所有后代节点组成的树。

遍历

访问树中所有节点的过程,常见的遍历方法包括前序遍历、中序遍历、后序遍历和层次遍历。

常见类型的树

二叉树

每个节点最多有两个子节点。

二叉查找树(BST)

左子树上所有节点的值都小于它的根节点的值;右子树上所有节点的值都大于它的根节点的值。

平衡二叉树

如AVL树或红黑树,它们通过某些机制保持树的平衡,确保基本操作的时间复杂度为O(log n)。

一种特殊的完全二叉树,分为最大堆和最小堆。


具体的代码框架如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>typedef char DATATYPE;
typedef struct BiTNode  /* 结点结构 */
{DATATYPE data;		/* 结点数据 */struct BiTNode *lchild,*rchild; /* 左右孩子指针 */
}BiTNode;char dat[]="abd##eh###c#fi###";
int ind;void CreateTree(BiTNode**root)
{char c = dat[ind++];if('#'==c){*root = NULL;}else  {*root = malloc(sizeof(BiTNode));if(NULL == *root ){printf("malloc error\n");return ;}(*root)->data = c;CreateTree(& (*root)->lchild);CreateTree(& (*root)->rchild);}return ;
}/*** @brief  根左右   前序* * @param root */
void PreOrderTraverse(BiTNode*root)
{if(NULL==root ){return ;}else  {printf("%c",root->data);//root PreOrderTraverse(root->lchild);// liftPreOrderTraverse(root->rchild);// right}}
/*** @brief 左根右   中序* * @param root */
void InOrderTraverse(BiTNode* root)
{if(NULL == root){return ;}InOrderTraverse(root->lchild);printf("%c",root->data);InOrderTraverse(root->rchild);
}/*** @brief 左右根    后序* * @param root */
void PostOrderTraverse(BiTNode* root)
{if(NULL == root){return ;}PostOrderTraverse(root->lchild);PostOrderTraverse(root->rchild);printf("%c",root->data);
}void DestroyBiTree(BiTNode*root)
{if(NULL ==root){return ;}DestroyBiTree(root->lchild);DestroyBiTree(root->rchild);free(root);}int	main(int argc, char **argv)
{BiTNode* root=NULL;CreateTree(&root);PreOrderTraverse(root);printf("\n");InOrderTraverse(root);printf("\n");PostOrderTraverse(root);printf("\n");DestroyBiTree(root);// system("pause");return 0;
}
//层序遍历
#define MAX_QUEUE_SIZE 100typedef struct {BiTNode* data[MAX_QUEUE_SIZE];int front;int rear;
} Queue;// 初始化队列
void InitQueue(Queue* q) {q->front = 0;q->rear = 0;
}// 判断队列是否为空
int IsQueueEmpty(Queue* q) {return q->front == q->rear;
}// 入队
void EnQueue(Queue* q, BiTNode* node) {if ((q->rear + 1) % MAX_QUEUE_SIZE == q->front) {printf("Queue is full\n");return;}q->data[q->rear] = node;q->rear = (q->rear + 1) % MAX_QUEUE_SIZE;
}// 出队
BiTNode* DeQueue(Queue* q) {if (IsQueueEmpty(q)) {return NULL;}BiTNode* node = q->data[q->front];q->front = (q->front + 1) % MAX_QUEUE_SIZE;return node;
}// 层序遍历
void LevelOrderTraverse(BiTNode* root) {if (NULL == root) {return;}Queue queue;InitQueue(&queue);EnQueue(&queue, root);while (!IsQueueEmpty(&queue)) {BiTNode* node = DeQueue(&queue);if (node != NULL) {printf("%c", node->data);  // 访问当前节点EnQueue(&queue, node->lchild);  // 左孩子入队EnQueue(&queue, node->rchild);  // 右孩子入队}}
}

http://www.dtcms.com/a/546819.html

相关文章:

  • 用cms做网站的缺点wordpress阅读设置
  • 求职网站开发开题报告flash网站开发工具
  • wap手机网站开发小规模企业所得税怎么算
  • 海淀重庆网站建设企业网站推广 知乎
  • 网站安全评估报告外贸订单流失严重
  • 如何做自己的论坛网站做非法网站要多少钱
  • 潮汕学院网站开发深圳门户网站建设公司
  • 【STL——set与multiset容器】
  • 泉州企业网站制作哪家好如何查看网站是否开启gzip
  • 建设银行 网站无法打开社区平安建设基层网站
  • dede企业网站源码wordpress怎么保持缩略图尺寸不变
  • NFS文件共享
  • 丹棱县 网站建设大型自助建站平台
  • 泰钢材企业网站源码wordpress wp_postmeta
  • 福建省住房城乡和城乡建设厅网站爱采购下载app
  • 做网站入门看什么书重庆企业网站开发服务
  • windows Qt6 vs2022编译配置以及使用QtXlsx库【超详细】
  • 网站文风wordpress 获取第一张图片
  • tp框架做网站的优点免费网络电话无限打不用充值
  • 做网站有送企业邮箱吗政务大厅网站建设管理制度
  • 营销型网站建设专家外贸在哪些网站开发客户
  • spring boot项目快速整合xxl-job实现定时任务
  • 防疫站24小时在线咨询建设教育网站怎么样
  • 将电脑做的网站放到外网住建部网站2015年城市建设统计
  • 站酷设计网站官网入口插画设计济宁亿峰科技做网站一年多少费用
  • 网站备案域名更改公司濮阳网络直播
  • 自学网站建设多久如何做网络推广人员
  • 荣成做网站中国建设法律法规网官方网站
  • 临海建设局官方网站文昌网站建设 myvodo
  • 运城住房和建设局网站新网站建设一般多少钱