Code/Resource
Windows Develop
Linux-Unix program
Internet-Socket-Network
Web Server
Browser Client
Ftp Server
Ftp Client
Browser Plugins
Proxy Server
Email Server
Email Client
WEB Mail
Firewall-Security
Telnet Server
Telnet Client
ICQ-IM-Chat
Search Engine
Sniffer Package capture
Remote Control
xml-soap-webservice
P2P
WEB(ASP,PHP,...)
TCP/IP Stack
SNMP
Grid Computing
SilverLight
DNS
Cluster Service
Network Security
Communication-Mobile
Game Program
Editor
Multimedia program
Graph program
Compiler program
Compress-Decompress algrithms
Crypt_Decrypt algrithms
Mathimatics-Numerical algorithms
MultiLanguage
Disk/Storage
Java Develop
assembly language
Applications
Other systems
Database system
Embeded-SCM Develop
FlashMX/Flex
source in ebook
Delphi VCL
OS Develop
MiddleWare
MPI
MacOS develop
LabView
ELanguage
Software/Tools
E-Books
Artical/Document
(7)树的建立和遍历.cpp
Package: datastruct1 [view]
Upload User: wxj1219
Upload Date: 2013-01-31
Package Size: 6k
Code Size: 1k
Category:
Data structs
Development Platform:
C/C++
- #include<conio.h>
- #include<iostream.h>
- struct Node
- {
- char Data;
- Node *Left,*Right;
- };
- Node *Root=NULL;
- char LeafCount=0;
- void Create(Node *&Tree)
- {
- char Char;
- Char=getch();
- cout<<Char;
- if(Char==' ')
- Tree=NULL;
- else
- {
- Tree=new Node;
- if(Root==NULL)
- Root=Tree;
- Tree->Data=Char;
- Create(Tree->Left);
- Create(Tree->Right);
- if((Tree->Left==NULL)&&(Tree->Right==NULL))
- LeafCount++;
- }
- }
- void PreOrder(Node *Tree)
- {
- if(Tree==NULL)
- return;
- cout<<Tree->Data;
- PreOrder(Tree->Left);
- PreOrder(Tree->Right);
- }
- void PostOrder(Node *Tree)
- {
- if(Tree==NULL)
- return;
- PostOrder(Tree->Left);
- PostOrder(Tree->Right);
- cout<<Tree->Data;
- }
- void InOrder(Node *Tree)
- {
- if(Tree==NULL)
- return;
- InOrder(Tree->Left);
- cout<<Tree->Data;
- InOrder(Tree->Right);
- }
- void Exchange(Node *Tree)
- {
- Node *TempNode;
- if(Tree==NULL)
- return;
- Exchange(Tree->Left);
- Exchange(Tree->Right);
- TempNode=Tree->Left;
- Tree->Left=Tree->Right;
- Tree->Right=TempNode;
- }
- void main()
- {
- clrscr();
- Create(Root);
- cout<<endl;
- PreOrder(Root);
- cout<<endl;
- PostOrder(Root);
- cout<<endl;
- InOrder(Root);
- cout<<endl;
- Exchange(Root);
- PreOrder(Root);
- cout<<endl;
- cout<<(int)LeafCount;
- }