数据结构与算法之二叉树(一)-----建立二叉树以及反转二叉树
2015-07-02 15:51
513 查看
/*递归建立遍历二叉树:注意都是以结点未操作对象*/ #include<iostream> using namespace std; struct BinaryTreeNode { char element;//节点内容 BinaryTreeNode *leftNode;//指向左节点 BinaryTreeNode *rightNode;//指向右节点 }; /*先序建立*/ void createBiTree(BinaryTreeNode* &q) { char c; cin >> c; if (c == '#') { q = NULL; } else { q = new BinaryTreeNode; q->element = c; createBiTree(q->leftNode); createBiTree(q->rightNode); } } /*翻转二叉树*/ void mirrorBinaryTree(BinaryTreeNode* &q) { if (q->element){ BinaryTreeNode *temp; temp = q->leftNode; q->leftNode = q->rightNode; q->rightNode = temp; } } /*先序遍历*/ void preOrderTraverse(BinaryTreeNode* &q) { if (q) { cout << q->element << endl; preOrderTraverse(q->leftNode); preOrderTraverse(q->rightNode); } } int main() { BinaryTreeNode *p; createBiTree(p); preOrderTraverse(p); mirrorBinaryTree(p); preOrderTraverse(p); return 0; }
相关文章推荐
- COJ979 WZJ的数据结构(负二十一)
- 编程之久除了算法和数据结构 什么也不属于我们
- 数据机构与算法-数据结构的一些基本概念
- 数据机构与算法-数据结构的一些基本概念
- 基于C语言的通用数据结构和算法库
- 【数据结构】Java单链表的逆序
- JS数据结构之BinarySearchTree
- COJ980 WZJ的数据结构(负二十)
- 数据结构与算法之七大排序总结
- raw数据结构
- 算法与数据结构先导章
- swift排序算法和数据结构
- E. GukiZ and GukiZianap平方分桶
- 算法与数据结构八日谈之二——动态规划
- php语言_数据结构_树_学习笔记
- Unity3D中常用的数据结构总结与分析
- 数据结构整理 第一章
- Swust 数据结构题目输出格式
- Redis各种数据结构(类型)的简要区别
- 数据结构之最短路径(Dijkstra 和 Floyed)