博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[haoi2009]巧克力
阅读量:6243 次
发布时间:2019-06-22

本文共 886 字,大约阅读时间需要 2 分钟。

         鉴于河南是oi弱省,所以想来这道题也没什么人会翻出来写吧,而且这还是haoi2009的一道简单题目,所以估计也没几个人会写博客的,那么看在我这么弱的份上,我觉得是应该写一篇出来的。

         这道题我是按照贪心写的(毕竟被划在贪心题中了),解题思想在于从大到小排列所有代价,别管是横着还是竖着,都是要排的,但横竖又是必不可少的,所以我们用一个结构体来记录代价和这个代价到底是横着切的还是竖着切的。用一个数组c[2]来分别记录横着切了几次和竖着切了几次,然后就是相乘后累加,关于这个,建议还是推一遍样例为好。

 

 

 

 

下面发代码:

#include <iostream>

#include <iomanip>

#include <cmath>

#include <cstdio>

#include <algorithm>

#include <cstring>

#include <ctime>

#include <functional>

using namespace std;

int n,m,i,ans;

int c[2];

struct lp

{

         int v;

         int c;

}a[20086];

bool cmp(lp a,lp b)

{return a.v>b.v;}

int main()

{

         cin>>n>>m;

         n--;m--;

         memset(c,0,sizeof(c));

         for(i=1;i<=n;i++)

         {cin>>a[i].v,a[i].c=0;}

         for(i=n+1;i<=n+m;i++)

         {cin>>a[i].v,a[i].c=1;}

         sort(a+1,a+n+m+1,cmp);

         for (i=1;i<=n+m;i++)

         {

                   c[a[i].c]++;

                   if(a[i].c==0)

                            ans+=a[i].v*(c[1]+1);

                   if(a[i].c==1)

                            ans+=a[i].v*(c[0]+1);

         }

         cout<<ans<<endl;

         return 0;

}

转载于:https://www.cnblogs.com/ywjblog/p/7596491.html

你可能感兴趣的文章
PHP递归生成树形数组
查看>>
学习RSA公开密钥算法
查看>>
教你摆脱低级程序猿 项目中cocopads的安装使用
查看>>
禁止火狐浏览器缓存input标签方法
查看>>
[ilink32 Error] Error: Unresolved external '__fastcall Data::Win::Adodb::TCustomADODataSet
查看>>
.NET Core:面向未来的开源跨平台开发技术
查看>>
常用正则表达式
查看>>
超大批量删除redis中无用key+配置
查看>>
guid正则表达
查看>>
Javascript的this用法
查看>>
PHP的学习--新特性
查看>>
Linux下安装配置Nexus
查看>>
JDBC插入数据超长时无法自动截断问题
查看>>
Tyrion中文文档(含示例源码)
查看>>
MySQL 面试基础
查看>>
利用GPU实现翻页效果
查看>>
C# 中的await
查看>>
java以流的形式输出文件
查看>>
『PyTorch』第十三弹_torch.nn.init参数初始化
查看>>
linux 查找目录下的文件内容并替换(批量)
查看>>