c/c++ 显示图形二叉树

效果图

在这里插入图片描述

头文件

#include<easyx.h>
#include<conio.h>

EasyX下载地址及文档

数据结构

二叉链表

typedef struct BSTNode {
 int key;
 BSTNode* lchild, * rchild;
}BSTNode,*BSTree;//二叉树结点

形状控制常量

//常量
const int WIN_X = 1000;
const int WIN_Y = 600;
const int UI_FAR_X = 220;
const int UI_FAR_Y = 20;

函数

void PrintTree(BSTree tree, int x, int y, float xFar, float yFar)
{
 if (tree->lchild)
 {
  line(x, y, x - xFar, y + yFar);
  PrintTree(tree->lchild, x - xFar, y + yFar, xFar / 2, yFar * 1.2);
 }
 if (tree)
 {
  setfillcolor(BLUE);
  fillcircle(x, y, 10);
  TCHAR num[10];
  _stprintf_s(num, _T("%d"), tree->key);
  outtextxy(x - 5, y - 5, num);
 }
 if (tree->rchild)
 {
  line(x, y, x + xFar, y + yFar);
  PrintTree(tree->rchild, x + xFar, y + yFar, xFar / 2, yFar * 1.2);
 }
}
void PrintUITree(BSTree tree)
{
 initgraph(WIN_X, WIN_Y);
 setbkcolor(CYAN);
 cleardevice();
 int flag = 0;
 PrintTree(tree, WIN_X / 2, 10, UI_FAR_X, UI_FAR_Y);
}

调用

PrintUITree(tree);

完整源码后期更新,敬请关注

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值