PTA5-6 修理牧场(队列模拟哈夫曼树)

1 篇文章 0 订阅
0 篇文章 0 订阅
5-6 修理牧场   (25分)
农夫要修理牧场的一段栅栏,他测量了栅栏,发现需要NN块木头,每块木头长度为整数L_iL
​i
​​ 个长度单位,于是他购买了一条很长的、能锯成NN块的木头,即该木头的长度是L_iL
​i
​​ 的总和。

但是农夫自己没有锯子,请人锯木的酬金跟这段木头的长度成正比。为简单起见,不妨就设酬金等于所锯木头的长度。例如,要将长度为20的木头锯成长度为8、7和5的三段,第一次锯木头花费20,将木头锯成12和8;第二次锯木头花费12,将长度为12的木头锯成7和5,总花费为32。如果第一次将木头锯成15和5,则第二次锯木头花费15,总花费为35(大于32)。

请编写程序帮助农夫计算将木头锯成NN块的最少花费。

输入格式:

输入首先给出正整数NN(\le 10^4≤10
​4
​​ ),表示要将木头锯成NN块。第二行给出NN个正整数(\le 50≤50),表示每段木块的长度。

输出格式:

输出一个整数,即将木头锯成NN块的最少花费。

输入样例:

8
4 5 1 2 1 3 1 1
输出样例:

49
把他分类为哈夫曼树,其实这题用到的是哈夫曼树的思想。
每次取当前队列中最小的两个值,一直累加,直到队列中只剩下一个值,就得到当前的最优解。
不bb,直接上图。

这里写图片描述

#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<ctime>
#include<string>
#include<stack>
#include<deque>
#include<queue>
#include<list>
#include<set>
#include<map>
#include<cstdio>
#include<limits.h>
#define MOD 1000000007
#define fir first
#define sec second
#define fin freopen("/home/ostreambaba/文档/input.txt", "r", stdin)
#define fout freopen("/home/ostreambaba/文档/output.txt", "w", stdout)
#define mes(x, m) memset(x, m, sizeof(x))
#define Pii pair<int, int>
#define Pll pair<ll, ll>
#define INF 1e9+7
#define inf 0x3f3f3f3f
#define Pi 4.0*atan(1.0)

#define lowbit(x) (x&(-x))
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define max(a,b) a>b?a:b

typedef long long ll;
typedef unsigned long long ull;
const double eps = 1e-9;
const int maxn = 10^3+100;
const int maxm = 1e6+10;
using namespace std;

inline int read(){
    int x(0),f(1);
    char ch=getchar();
    while (ch<'0'||ch>'9') {if (ch=='-') f=-1;ch=getchar();}
    while (ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar();
    return x*f;
}
int main()
{
    int n,m;
    cin>>n;
    int l[10010];
    int re=0;
    priority_queue<int,vector<int>,greater<int> >que;
    for(int i=0;i<n;++i){
        cin>>l[i];
        que.push(l[i]);
        re+=l[i];
    }
    int sum,tmp1,tmp2;
    sum=0;
    //que.pop();
    while(que.size()>1){
        tmp1=que.top();
        que.pop();
        tmp2=que.top();
        que.pop();
        que.push(tmp1+tmp2);
        sum=sum+tmp1+tmp2;
    }
    cout<<sum<<endl;
    return 0;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue2项目的目录结构通常如下: ``` ├── build // 项目构建相关的代码 │ ├── build.js // 生产环境构建代码 │ ├── check-versions.js // 检查node、npm等版本 │ ├── dev-client.js // 开发服务器热重载配置 │ ├── dev-server.js // 开发服务器配置 │ ├── utils.js // 构建相关工具方法 │ ├── webpack.base.conf.js // webpack基础配置 │ ├── webpack.dev.conf.js // webpack开发环境配置 │ └── webpack.prod.conf.js // webpack生产环境配置 ├── config // 项目开发环境配置 │ ├── dev.env.js // 开发环境变量 │ ├── index.js // 项目配置文件 │ ├── prod.env.js // 生产环境变量 │ └── test.env.js // 测试环境变量 ├── src // 源码目录 │ ├── assets // 资源目录,如图片、字体等 │ ├── components // 公共组件目录 │ ├── router // 前端路由 │ ├── store // 应用级数据(state)管理目录 │ ├── utils // 工具函数目录 │ ├── views // 页面目录 │ ├── App.vue // 主组件 │ └── main.js // 入口文件 ├── static // 静态资源目录,如图片、字体等 ├── test // 测试相关目录 ├── .babelrc // babel配置文件 ├── .editorconfig // 定义代码格式 ├── .eslintignore // eslint忽略目录或文件 ├── .eslintrc.js // eslint配置文件 ├── .gitignore // git忽略目录或文件 ├── .postcssrc.js // postcss配置文件 ├── index.html // 项目入口文件 └── package.json // 项目基本信息 ``` 其,`build`目录存放构建相关的代码,`config`目录存放项目开发环境的配置,`src`目录存放源码,`static`目录存放静态资源,`test`目录存放测试相关的代码。 `src`目录下,`assets`目录存放各种资源文件,如图片、字体等;`components`目录存放公共组件;`router`目录存放前端路由相关代码;`store`目录存放应用级数据(state)管理相关代码;`utils`目录存放工具函数相关代码;`views`目录存放页面相关代码;`App.vue`是主组件;`main.js`是入口文件。 以上是一个常见Vue2项目目录结构,具体项目可能会略有差异。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值