C語言二叉樹實驗報告流程圖,二叉樹的建立與遍歷實驗報告(c語言編寫,附源代碼).doc...

二叉樹的建立與遍歷實驗報告(c語言編寫,附源代碼).doc

第 1 頁,共 9 頁二叉樹的建立與遍歷實驗報告級 班 年 月 日 姓名 學號_ 1實驗題目建立一棵二叉樹,并對其進行遍歷(先序、中序、后序),打印輸出遍歷結果。2需求分析本程序用 VC 編寫,實現建立一棵二叉樹的功能,并對其進行遍歷(先序、中序、后序),并且打印輸出遍歷結果。 輸入的形式和輸入值的范圍輸入二叉樹的先序,當其結點為空時,需要輸入。(輸入的先序僅含字母和) 輸出的形式輸出二叉樹的先序、中序、后序。 程序所能達到的功能實現建立一棵二叉樹的功能,并對其進行遍歷(先序、中序、后序),并且打印輸出遍歷結果。 測試數據輸入數據輸入 ABCDEGF輸出結果二叉樹的先序遍歷為ABCDEGF二叉樹的中序遍歷為CBEGDFA二叉樹的后序遍歷為CGEFDBA3概要設計1 為了實現上述程序功能,需要定義二叉鏈表的抽象數據類型typedef struct BinaryTreeNode TElemType data;二叉樹結點中的數據域struct BinaryTreeNode *lchild , *rchild; 二叉樹結點的左孩子和右孩子指針BinaryTreeNode ,*BiTree;第 2 頁,共 9 頁基本操作A. void CreateBinaryTree BiTree 3中序遍歷二叉樹,并且輸出中序遍歷的結果 void MidOrderBiTree T; 4序遍歷二叉樹,并且輸出后序遍歷的結果 void PostOrderBiTree T; 5各函數間關系如下主函數 mainCreateBinaryTree PreOrder MidOrder PostOrder第 3 頁,共 9 頁4詳細設計1 二叉鏈表的定義typedef struct BinaryTreeNode定義一個樹結點的數據域;定義一個該結點的左孩子指針和右孩子指針;2 void CreateBinaryTree BiTree if輸入字符 T 指針置值為 NULL;else 動態申請一個指向二叉樹結構體的指針把輸入字符賦值給新指針的數據域 data;調用 CreateBinaryTree新指針的 lchild 成員;調用 CreateBinaryTree新指針的 rchild 成員;3 void PreOrderBiTree T 先序遍歷二叉樹ifT指針不為NULL輸出T的data域;先序遍歷左子樹; 先序遍歷右子樹;第 4 頁,共 9 頁4 void MidOrderBiTree T 中序遍歷二叉樹ifT指針不為NULL中序遍歷左子樹;輸出T的data域;中序遍歷右子樹;5 void PostOrderBiTree T 中序遍歷二叉樹ifT指針不為NULL后序遍歷左子樹;后序遍歷右子樹;輸出T的data域;5調試分析在編寫程序過程中,我將 scanf(”c”,typedef struct BinaryTreeNode二叉鏈表的存儲結構TElemType data;struct BinaryTreeNode *lchild , *rchild;BinaryTreeNode ,*BiTree;void CreateBinaryTree BiTree scanf“c“,ifch TNULL;else ifT BinaryTreeNode *malloc sizeofBinaryTreeNode exit -1;判斷 malloc 函數是否獲得符合要求的內存塊,是則繼續程序,否則使用 exit 函數強制退出程序第 7 頁,共 9 頁如果 malloc 函數無法獲得符合要求的內存塊,malloc 函數會返回 NULL 指針T-datach;CreateBinaryTreeT-lchild;CreateBinaryTreeT-rchild;void PreOrderBiTree T先序遍歷二叉樹ifTprintf“c “,T-data;PreOrderT-lchild; PreOrderT-rchild;void MidOrderBiTree T中序遍歷二叉樹ifTMidOrderT-lchild;第 8 頁,共 9 頁printf“c “,T-data;MidOrderT-rchild;void PostOrderBiTree T后序遍歷二叉樹ifTPostOrderT-lchild;PostOrderT-rchild;printf“c “,T-data;void mainBiTree Tree;printf“輸入字符,先序建立二叉樹n“;CreateBinaryTreeTree;printf“二叉樹的先序遍歷為n“;PreOrderTree;printf“n 二叉樹的中序遍歷為n“;第 9 頁,共 9 頁MidOrderTree;printf“n 二叉樹的后序遍歷為n“;PostOrderTree;getchar;getchar;

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/397424.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/397424.shtml
英文地址,請注明出處:http://en.pswp.cn/news/397424.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

三角函數泰勒展開C語言,第六章-函數作業 ---三角函數泰勒級數展開式計算正弦函數值...

E201_06_02_正弦函數題目要求:按照三角函數泰勒級數展開式計算正弦函數值:,直到最后一項的絕對值小于106解題思路:1. 輸入弧度2. 確定初始化值3. 求階梯函數代碼:public class E201_06_02_正弦函數 {public static void main(Stri…

Codeforces Round #325 (Div. 2) B. Laurenty and Shop 前綴和

B. Laurenty and Shop Time Limit: 1 Sec Memory Limit: 256 MB 題目連接 http://codeforces.com/contest/586/problem/BDescription A little boy Laurenty has been playing his favourite game Nota for quite a while and is now very hungry. The boy wants to make sau…

python學習感悟第3節

在繼列表的學習之后,進行了元組的學習。元組和列表功能相似,只是元組不能進行修改,所以元組又叫只讀列表。 下面列舉的是一系列的字符串操作: name.capitalize() #首字母大寫 name.count("a") #數列表中有幾個a name…

MyBatis_ibatis和mybatis的區別【轉】

1. ibatis3.*版本以后正式改名為mybaits&#xff0c;它也從apache轉到了google code下&#xff1b;也就是說ibatis2.*&#xff0c;mybatis3.*。2. 映射文件的不同ibatis的配置文件如下<?xml version"1.0" encoding"UTF-8" ?><!DOCTYPE sqlMapCo…

android gallery自動播放,可循環顯示圖像的Android Gallery組件

類型&#xff1a;源碼相關大小&#xff1a;23.6M語言&#xff1a;中文 評分&#xff1a;9.1標簽&#xff1a;立即下載第 4 頁 實現循環顯示圖像的Gallery組件實現循環顯示圖像的Gallery組件在本節將組出與循環顯示圖像相關的ImageAdapter類的完整代碼。讀者可以從中看到上一節介…

docker內程序如何讀取dockerfile和compose.yml中設置的環境變量

docker內程序如何讀取dockerfile和compose.yml中設置的環境變量 背景 compose文件中配置了服務A和服務B&#xff0c;其中B服務調用了A服務的接口&#xff0c;那么B的實現代碼中該如何調用A的服務呢&#xff1f; 解決 compose文件中&#xff0c;服務B的配置加入A的接口&#xff…

2015年10月13日

關于掙錢&#xff0c;我覺得&#xff0c;只要興趣所在&#xff0c;能把事做好&#xff0c;錢自己就會來。收入上不去&#xff0c;往往是做的事情就不在高收入的那個區間&#xff0c;寫程序很難出富翁。說實話&#xff0c;外圍一天的消費可能就是你工資的好幾倍&#xff0c;不用…

Spring Boot Servlet

上一篇我們對如何創建Controller 來響應JSON 以及如何顯示數據到頁面中&#xff0c;已經有了初步的了解。 Web開發使用 Controller 基本上可以完成大部分需求&#xff0c;但是我們還可能會用到 Servlet、Filter、Listener、Interceptor 等等。 當使用spring-Boot時&#xff0c;…

基于相關性分析系統性能瓶頸

測試的過程中&#xff0c;難免需要會遇到一些性能瓶頸&#xff0c;那么就要求我們能夠分析出性能瓶頸&#xff0c;并給出解決方案。性能瓶頸很抽象&#xff0c;我們可以通過數據使其具象。以我工作內容為例&#xff0c;服務器處理數據的能力是有限的&#xff0c;那么其處理的邊…

curl網站開發指南

curl網站開發指南 作者&#xff1a; 阮一峰 日期&#xff1a; 2011年9月 4日 我一向以為&#xff0c;curl只是一個編程用的函數庫。 最近才發現&#xff0c;這個命令本身&#xff0c;就是一個無比有用的網站開發工具&#xff0c;請看我整理的它的用法。 curl網站開發指南 阮一…

android格式化時間中文版,Android 仿微信聊天時間格式化顯示功能

本文給大家分享android仿微信聊天時間格式化顯示功能。在同一年的顯示規則&#xff1a;如果是當天顯示格式為 HH:mm 例&#xff1a;14:45如果是昨天,顯示格式為 昨天 HH:mm 例&#xff1a;昨天 13:12如果是在同一周 顯示格式為 周一 HH:mm 例&#xff1a;周一14:05如果不是同一…

java分享第十七天-01(封裝操作xml類)

做自動化測試的人&#xff0c;都應該對XPATH很熟悉了&#xff0c;但是在用JAVA解析XML時&#xff0c;我們通常是一層層的遍歷進去&#xff0c;這樣的代碼的局限性很大&#xff0c;也不方便&#xff0c;于是我們結合一下XPATH&#xff0c;來解決這個問題。所需要的JAR包&#xf…

Ubuntu12.04 內核樹建立

先查看自己使用的內核版本 linlin-virtual-machine:~$ uname -r 3.2.0-23-generic 如果安裝系統時&#xff0c;自動安裝了源碼。在 /usr/src 目錄下有對應的使用的版本目錄。 linlin-virtual-machine:~$ cd /usr/src linlin-virtual-machine:/usr/src$ ls linux-headers-3.2.0…

【mysql】Innodb三大特性之double write

1、doublewrite buffer&#xff08;mysql官方的介紹&#xff09; InnoDB uses a novel file flush technique called doublewrite. Before writing pages to the data files, InnoDB first writes them to a contiguous area called the doublewrite buffer. Only after the wr…

android crop 大圖,com.android.camera.action.CROP 實現圖片剪裁

APP 中選取圖片之后&#xff0c;有時候需要進行剪裁&#xff0c;比如頭像。以下是啟動代碼。在我的項目中&#xff0c;傳的是 filePath&#xff0c;所以我轉了一下&#xff0c;但實際上從相冊選擇圖片后&#xff0c;用 data.getData() 就可獲得 uri。Uri uri Uri.fromFile(new…

Who Gets the Most Candies? POJ - 2886 (線段樹)

按順時針給出n個小孩&#xff0c;n個小孩每個人都有一個紙&#xff0c;然后每個人都有一個val&#xff0c;這個val等于自己的因子數&#xff0c;如果這個val是正的&#xff0c;那就順時針的第val個孩子出去&#xff0c;如果是負的話&#xff0c;就逆時針的第val個孩子出去&…

javax.validation.ValidationException: Unable to find a default provider

2019獨角獸企業重金招聘Python工程師標準>>> [ERROR] [2016-11-16 13:58:21 602] [main] (FrameworkServlet.java:457) Context initialization failed org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframewo…

第十章練習題----2

package com.Hanqi2;public class xitizhuhanshu {public static void main(String[] args) {// TODO Auto-generated method stubxiti tm new xiti("黑色","15寸");xitizhs tm3 new xitizhs("藍色","15寸");tm.Call("654"…

關于微信“被返回頁”在被返回時自動刷新

網上有很多這些文章&#xff0c;但我覺得沒一篇真正解決這個問題&#xff0c;倒是能給人一個解決方案的思路&#xff0c;對&#xff0c;就是posState事件。 要解決這個問題也不難&#xff0c;使用history的replaceState屬性替換當前網頁鏈接&#xff08;其實作用是在不增加hist…

android視頻播放器api,03.視頻播放器Api說明

03.視頻播放器Api說明目錄介紹01.最簡單的播放02.如何切換視頻內核03.切換視頻模式04.切換視頻清晰度05.視頻播放監聽06.列表中播放處理07.懸浮窗口播放08.其他重要功能Api09.播放多個視頻10.VideoPlayer相關Api11.Controller相關Api12.邊播放邊緩存api13.類似抖音視頻預加載14…