C语言数据库-二叉树
一、定义
二、基本概念

(2)只有一个根结点的二叉树——如图(b);
三、类型
四、相关术语
// main.c
// C语言-二叉树
//
// Created by rimi on 2017/5/24.
// Copyright © 2017年 rimi. All rights reserved.
#include <stdio.h>
#include <stdlib.h>
struct TreeNode {
char data;
struct TreeNode * left;
struct TreeNode * right;
};
// 创建树
struct TreeNode * createTree();
// 先序遍历
void preTraverse(struct TreeNode * root);
// 中序遍历
void centerTraverse(struct TreeNode * root);
// 后序遍历
void backTraverse(struct TreeNode * root);
int main(int argc, const char * argv[]) {
// preTraverse(createTree());
centerTraverse(createTree());
// backTraverse(createTree());
return ;
}
// 创建树
struct TreeNode * createTree(){
struct TreeNode * pa = (struct TreeNode *)malloc(sizeof(struct TreeNode));
struct TreeNode * pb = (struct TreeNode *)malloc(sizeof(struct TreeNode));
struct TreeNode * pc = (struct TreeNode *)malloc(sizeof(struct TreeNode));
struct TreeNode * pd = (struct TreeNode *)malloc(sizeof(struct TreeNode));
struct TreeNode * pe = (struct TreeNode *)malloc(sizeof(struct TreeNode));
struct TreeNode * pf = (struct TreeNode *)malloc(sizeof(struct TreeNode));
struct TreeNode * pg = (struct TreeNode *)malloc(sizeof(struct TreeNode));
pa->data = 'A';
pb->data = 'B';
pc->data = 'C';
pd->data = 'D';
pe->data = 'E';
pf->data = 'F';
pg->data = 'G';
pa->left = pb;
pa->right = pc;
pb->left = pd;
pb->right = NULL;
pc->left = pe;
pc->right = pf;
pd->left = NULL;
pd->right = pg;
pe->left = NULL;
pe->right = NULL;
pf->left = NULL;
pf->right = NULL;
pg->left = NULL;
pg->right = NULL;
return pa;
}
// 先序遍历
void preTraverse(struct TreeNode * root){
if (root != NULL) {
printf("%c\n", root->data);
preTraverse(root->left);
preTraverse(root->right);
}
}
// 中序遍历
void centerTraverse(struct TreeNode * root){
if(root !=NULL) {
centerTraverse(root ->left);
printf("%c \n",root ->data);
centerTraverse(root->right);
}
}
// 后序遍历
void backTraverse(struct TreeNode * root){
if(root !=NULL){
backTraverse(root ->left);
backTraverse(root ->right);
printf("%c \n",root ->data);
}
}
C语言数据库-二叉树的更多相关文章
- C语言数据库编程
----摘自个人C语言数据库项目报告 3.4逻辑结构的SQL语句实现 创建基本表: 3.4-1建立商品表: create table goods(goods_id int primary key,go ...
- C语言实现二叉树-02版
---恢复内容开始--- 昨天,提交完我们的二叉树项目后,今天早上项目经理早早给我打电话: 他说,小伙子干的不错.但是为什么你上面的insert是recusive的呢? 你难道不知道万一数据量大啦!那 ...
- C语言实现二叉树-利用二叉树统计单词数目
昨天刚参加了腾讯2015年在线模拟考: 四道大题的第一题就是单词统计程序的设计思想: 为了记住这一天,我打算今天通过代码实现一下: 我将用到的核心数据结构是二叉树: (要是想了解简单二叉树的实现,可以 ...
- Atitit.跨语言数据库db api兼容性 jdbc odbc ado oledb 增强方案
Atitit.跨语言数据库db api兼容性 jdbc odbc ado oledb 增强方案 1. 跨语言db api兼容性..1 2. 目前访问数据库的接口很多.比较常用的jdbc odbc 以 ...
- C语言实现二叉树
二叉树的重要性就不用多说啦: 我以前也学习过,但是一直没有总结: 网上找到的例子,要么是理论一大堆,然后是伪代码实现: 要么是复杂的代码,没有什么解释: 最终,还是靠FQ找到一些好的文章,参考地址我会 ...
- C语言实现二叉树的基本操作
二叉树是一种非常重要的数据结构.本文总结了二叉树的常见操作:二叉树的构建,查找,删除,二叉树的遍历(包括前序遍历.中序遍历.后序遍历.层次遍历),二叉搜索树的构造等. 1. 二叉树的构建 二叉树的基本 ...
- R语言︱ 数据库SQL-R连接与SQL语句执行(RODBC、sqldf包)
要学的东西太多,无笔记不能学~~ 欢迎关注公众号,一起分享学习笔记,记录每一颗"贝壳"~ --------------------------- 数据库是极其重要的R语言数据导入源 ...
- C语言描述二叉树的实现及操作(链表实现)
概述 二叉树为每个节点最多有两个儿子节点(左儿子节点和右儿子节点)的树. 前序遍历:根结点 ---> 左子树 ---> 右子树. 中序遍历:左子树---> 根结点 ---&g ...
- 使用go语言数据库
1.下载并导入数据库驱动包(注意配置环境变量.数据库.go.以及ENV) 这里选择了Go-MySQL-Driver这个实现.地址是:https://github.com/go-sql-driver/m ...
随机推荐
- Nodejs第一天-{Nodejs基础 深刻理解浏览器 环境变量 基础语法}
Nodejs第一天 1.什么是Nodejs Nodejs是一个可以运行(解析)ECMAScript的环境; ECMAScript是规定了一些列的语法 ,这些语法想要解析的执行就需要放在某个环境 ...
- 每周psp-第五周
PSP表格: 类别 任务 开始时间 结束时间 中断时间 delta时间 开会 scrum立会 10.13下午6:04 10.13下午6:34 0 30 开会 scrum立会 10.14下午6:02 1 ...
- c++ string需要注意的地方
There are multiple answers based on what you are doing with the string. 1) Using the string as an id ...
- C语言 内存分配 地址 指针 数组 参数 实例解析
. Android源码看的鸭梨大啊, 补一下C语言基础 ... . 作者 : 万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/detai ...
- TCP 的有限状态机
TCP 有限状态机的图中每一个方框都是 TCP 可能具有的状态. 每个方框中的大写英文字符串是 TCP 标准所使用的 TCP 连接状态名. 状态之间的箭头表示可能发生的状态变迁. 箭头旁边的字,表明引 ...
- Crash使用参考
整理自man 8 crash 1.简介 Crash工具可以用来分析一个正在运行的内核,也可以用来分析一个内核的crash dump文件,这里说的是内核代码异常产生的crash dump文件,不是应用层 ...
- Thinkphp5的使用phpmailer实现发邮件功能(163邮箱)
Thinkphp5本身并没有实现发邮件的功能,至少据我所知. 本文利用网易邮箱作为发邮件的邮箱.作为发送邮件的前提是需要开启SMTP服务,打开网易邮件,点击设置按钮,如下图所示 勾选smtp服务 保存 ...
- isset、is_null、empty的区别
版本:PHP 5.4 1.isset() :检测变量是否存在,测试如下: $a = false; $b = null; $c; $d = 0; $e = true; var_dump(isset($a ...
- bzoj2437-兔兔与蛋蛋
题目 分析 第一次做这种题,其实很简单. 只能经过一次的博弈可以考虑转化为二分图博弈. 棋盘上有黑白色的棋子,可以把这个游戏看作空格在棋子间移动,于是就想到,把棋盘黑白染色,以空格为黑,那么空格的移动 ...
- BZOJ4767 两双手(组合数学+容斥原理)
因为保证了两向量不共线,平面内任何一个向量都被这两个向量唯一表示.问题变为一张有障碍点的网格图由左上走到右下的方案数. 到达终点所需步数显然是平方级别的,没法直接递推.注意到障碍点数量很少,那么考虑容 ...