首页 > 其他 > 详细

TYVJ 1094 矩形分割

时间:2017-10-09 19:07:32      阅读:327      评论:0      收藏:0      [点我收藏+]
时间: 1000ms / 空间: 131072KiB / Java类名: Main

背景

YHOI Train#4 Problem 1

描述

出于某些方面的需求,我们要把一块N×M的木板切成一个个1×1的小方块。
对于一块木板,我们只能从某条横线或者某条竖线(要在方格线上),而且这木板是不均匀的,从不同的线切割下去要花不同的代价。而且,对于一块木板,切割一次以后就被分割成两块,而且不能把这两块木板拼在一起然后一刀切成四块,只能两块分别再进行一次切割。
现在,给出从不同的线切割所要花的代价,求把整块木板分割成1×1块小方块所需要耗费的最小代价。

输入格式

输入文件第一行包括N和M,表示长N宽M的矩阵。
第二行包括N-1个非负整数,分别表示沿着N-1条横线切割的代价。
第二行包括M-1个非负整数,分别表示沿着M-1条竖线切割的代价。

输出格式

输出一个整数,表示最小代价。

测试样例1

输入

2 2 

输出

9

备注

对于60%的数据,有1 ≤ N ,M≤ 100;
对于100%的数据,有1 ≤ N,M ≤ 2000。
 
 
题目大意:把一个n*m的矩形切成1*1的小正方形,不能叠着切。
每切一刀都有代价,求最少代价。
题解:贪心。
先把代价大的那一刀给切了。
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define LL long long
#define maxn 2017
#define inf 100000000
using namespace std;

int l1,l2,n,m,vc,vr,row[maxn],col[maxn];
LL ans;

int main(){
    scanf("%d%d",&n,&m);
    for(int i=1;i<n;i++)scanf("%d",&row[i]);
    for(int i=1;i<m;i++)scanf("%d",&col[i]);
    sort(row+1,row+n);sort(col+1,col+m);
    l1=n-1;l2=m-1;vc=1;vr=1;
    while(1){
        if(!l1&&!l2)break;
        if(l1==0)row[l1]=-inf;
        if(l2==0)col[l2]=-inf;
        if(row[l1]>=col[l2]){
            vr++;
            ans+=vc*row[l1--];
        }else  vc++,ans+=vr*col[l2--];
    }
    printf("%lld\n",ans);
    return 0;
}

 

 

TYVJ 1094 矩形分割

原文:http://www.cnblogs.com/zzyh/p/7642475.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!