北航计算机2018年复试-机试第2题

本文分享了2018年北京航空航天大学计算机专业复试中机试的第二题,主要涉及C语言编程技巧和解题经验。
摘要由CSDN通过智能技术生成

 喜鹊筑巢

#include<stdio.h>

#define max 100

struct node{
	struct node *lchild;
	struct node *mchild;
	struct node *rchild;
	int layer;//深度
	int index;//序号
	int childnum;//孩子数量
	int preOrder;
}Nodes[max],*TreeNode;
int needIndex;
int preOrder=1;
int cmp(struct node a,struct node b){
	if(a.childnum>b.childnum)
		return 1;
	else if(a.childnum==b.childnum&&a.layer>b.layer)
		return 1;
	else if(a.childnum==b.childnum&&a.layer==b.layer&&a.preOrder<b.preOrder)
		return 1;
	else
		return 0;
}
void PreOrder(struct node *root){
	root->preOrder=preOrder++;
	if(root->lchild!=NULL){
		root->lchild->layer=root->layer+1;
		PreOrder(root->lchild);
	}
	if(root->mchild!=NULL){
		root->mchild->layer=root->layer+1;
		PreOrder(root->mchild);
	}
	if(root->rchild!=NULL){
		root->rchild->layer=root->layer+1;
		PreOr
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值