l蓝桥杯备战- Huffuman树

来源:互联网 发布:淘宝买伟哥会打电话 编辑:程序博客网 时间:2024/05/16 01:15
思路:(1)输入一个数组
      (2)将数组按从小到大的顺序排列,可以用sort()函数
      (3)将数组的前两个元素相加,并去掉,并存入他们之和进入数组
      (4)循环内容(2)(3),条件是1,使用理由是:让数组中元素只留下一个元素;
题目:
问题描述
  Huffman树在编码中有着广泛的应用。在这里,我们只关心Huffman树的构造过程。
  给出一列数{pi}={p0, p1, …, pn-1},用这列数构造Huffman树的过程如下:
  1. 找到{pi}中最小的两个数,设为pa和pb,将pa和pb从{pi}中删除掉,然后将它们的和加入到{pi}中。这个过程的费用记为pa + pb。
  2. 重复步骤1,直到{pi}中只剩下一个数。
  在上面的操作过程中,把所有的费用相加,就得到了构造Huffman树的总费用。
  本题任务:对于给定的一个数列,现在请你求出用该数列构造Huffman树的总费用。


  例如,对于数列{pi}={5, 3, 8, 2, 9},Huffman树的构造过程如下:
  1. 找到{5, 3, 8, 2, 9}中最小的两个数,分别是2和3,从{pi}中删除它们并将和5加入,得到{5, 8, 9, 5},费用为5。
  2. 找到{5, 8, 9, 5}中最小的两个数,分别是5和5,从{pi}中删除它们并将和10加入,得到{8, 9, 10},费用为10。
  3. 找到{8, 9, 10}中最小的两个数,分别是8和9,从{pi}中删除它们并将和17加入,得到{10, 17},费用为17。
  4. 找到{10, 17}中最小的两个数,分别是10和17,从{pi}中删除它们并将和27加入,得到{27},费用为27。
  5. 现在,数列中只剩下一个数27,构造过程结束,总费用为5+10+17+27=59。
输入格式
  输入的第一行包含一个正整数n(n<=100)。
  接下来是n个正整数,表示p0, p1, …, pn-1,每个数不超过1000。
输出格式
  输出用这些数构造Huffman树的总费用。
样例输入
5
5 3 8 2 9
样例输出
59
代码如下:
#include <iostream>
#include <algorithm>
using namespace std;
int a[100];
int main()
{
    int n;
    cin>>n;
    long long sum=0;
    int i,j=0,t=n;
    for(i=0;i<n;i++)
      cin>>a[i];
    while(1)//妙哉 
     {
        if(j<n-1){
        sort(a+j,a+n);//数组的sort()函数排序,j是用于去数组范围的 
        sum+=(a[j]+a[j+1]);//费用
        a[j+1]+=a[j];//将sum的值输入数组 
        j++;}//循环继续 
        else//j若不符合条件,则退出 
        break;
         
     }
       
    cout<<sum<<endl;
return 0;
}
自己写的代码:
#include<iostream>
#include<algorithm>
using namespace std;
#define Max 101
bool com(int a,int b)//将数组有大到小排列
{
if(a<b)
return 0;
else
return 1;
}
int main()
{
int a[Max];
int n;
cin>>n;
for(int i=0;i<n;i++)
cin>>a[i];
int sun=0;
for(int i=n;i>1;i--)
{
sort(a,a+i,com);//将数组有大到小排列
int t=(a[i-2]+a[i-1]);
sun+=t;//求和

a[i-2]=t;//放入数组中


}
   cout<<sun<<endl;
return 0;
}
由题意知:输入n,表示输入n个数构成一个数组
    例如:输入5,在设置数组a,然后给数组a赋值5个数分别为5 3 8 2 9
          去数组中两个最小的相加,去掉两个最小的,然后,加入那两个最小的数之和
          还要将每次求得的两个数的最小之和相加;
需要严谨的逻辑:
        1:输入n,在输入数组值
    
        2:将数组用sort函数全排为2 3 5 8 9,然后将a[0]+a[1]赋值给sum=5,再将a[0]加到
                   a[1]中,则数组就为2 5 5 8 9,此时目标是,5 5 8 9,再利用sort(a+1,a+n)
                   sort函数与数组有个方便时,在sort里可以指明排列哪段,就比如,题目要我们每次
                   找出最小,和第二小的两个数相加后,将两个数去掉,再将他们之和加入数组,此时
                   sort函数就起到作用了,可以 忽略第二个数,然后将sum把第二个数覆盖掉,去选定
                   区域重复以上说的
           
         3:重复方式,可以用while循环,判断循环要循环几次,利用if else语句if成立时继续上面的
                      思想,不符合后,直接break退出循环,循环条件1,

0 0