机试练习Day3-二叉树题目

哈夫曼树

第一行输入一个数n,表示叶结点的个数,需要用这些叶结点生成哈夫曼树。题目需要输出所有结点的值与权值的乘积之和的最小值。

基础知识

  • 哈夫曼树的构成过程。
  • sort()函数的参数。

简单图解

在这里插入图片描述
自己手动计算的过程其实很简单:每次选择两个最小的数,相加之后存入数组,但之前的两个数就没用了,然后把这个计算结果加到最后的值里面,而最后输出的结果就是这些和的和【哈夫曼树的带权路径长度 = 非叶子结点的权值之和】。但是问题是如何做到废除相加的两个数、如何把新的结果存起来。

  • 解决思路:考虑到每次得出结果之后都需要更新数组重新排序,所以想到了循环,再利用循环每次+1的特点废除第一个因子,并把结果存到第二个因子的位置以此废除第二个因子。

代码展示

#include<bits/stdc++.h>
using namespace std;

int main()
{
	int n,weight;
	int number[1000];
	while(cin>>n)
	{
		weight=0;
		for(int i=0;i<n;i++)
			cin>>number[i];
		//因为涉及到加法次数,所以j的上限很重要
		for(int j=0;j<n-1;j++)
		{
			//每次循环j++后,从新的j开始刚好是一个新的数组
			//注意:number数组中一直是5个数,所以第二个参数不能改
			sort(number+j,number+n);
			//这里仅仅是改变了number[j+1]的值
			//至于number[j]的值就没那么重要了,因为下次排序不会用
			number[j+1]=number[j]+number[j+1];
			weight=weight+number[j+1];
		}
		cout<<weight<<endl;
	}
}

二叉排序树

输入一系列整数,建立二叉排序树,并进行前序,中序,后序遍历。但是,重复的数据不参与建树。

基础知识

  • 二叉排序树的定义、构建。
  • 树的遍历。

代码展示

#include<bits/stdc++.h>
using namespace std;

typedef struct tree
{
	int data;
	tree *lchild;
	tree *rchild;
}tree;

tree* buildtree(tree* root,int a)
{
	if(root==NULL)
	{
		//给根节点申请一个空间
		root=(tree*)malloc(sizeof(tree));
		root->lchild=NULL;
		root->rchild=NULL;
		root->data=a;
		return root;
	}
	//直接不考虑相等的情况是不行的,因为要考虑函数的返回值
	if(root->data==a)
		return root;
	if(root->data>a)
		root->lchild=buildtree(root->lchild,a);
	if(root->data<a)
		root->rchild=buildtree(root->rchild,a);
	return root;
}
//前序遍历
void pre(tree* root)
{
	if(root!=NULL)
	{
		cout<<root->data<<" ";
		pre(root->lchild);
		pre(root->rchild);
	}
}
//中序遍历,如果是复制的前序遍历的代码,不要忘记改函数体里面的名字
void mid(tree* root)
{
	if(root!=NULL)
	{
		mid(root->lchild);
		cout<<root->data<<" ";
		mid(root->rchild);
	}
}
//后序遍历,如果是复制的前序遍历的代码,不要忘记改函数体里面的名字
void pro(tree* root)
{
	if(root!=NULL)
	{
		pro(root->lchild);
		pro(root->rchild);
		cout<<root->data<<" ";
	}
}
	
int main()
{
	int x;
	while(cin>>x)
	{
		//每次置空的时间看好,位置不要搞错了
		tree *root=NULL;
		while(x--)
		{
			int a;
			//不要忘记cin>>a
			cin>>a;
			//buildtree函数返回值要接收的
			root=buildtree(root,a);
		}
		pre(root);
		cout<<endl;
		mid(root);
		cout<<endl;
		pro(root);
		cout<<endl;		
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只天蝎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值