【Luogu3444】ORK-Ploughing(贪心)

题面

Luogu

题解

我们知道,如果我们选定了以横向为主,或者纵向为主,

那么就有尽可能减少另一个方向上耕地的次数

所以分开贪心,但是本质相同,所以接下来只考虑纵向为主

既然确定了以纵向为主,那么就要尽可能减少横向操作的次数

所以,只要能够纵向耕地,就不考虑横向耕地

可是,如果到了某个时候,纵向无法耕了

此时必须横向耕

但是我们不知道应该从上面开始还是下面开始

为了解决这个问题

我们假设上面最多耕的次数是有限次

换种想法,我们假设上面至少耕这么多次

既然上面的次数确定,那么下方的耕地次数越少越好

所以耕地的优先级:

左-右-上-下

只要能够耕就一定耕

这样,枚举-贪心的做法就可以做啦

横向、纵向分别算一遍

时间复杂度O((n+m)^2)

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<queue>
using namespace std;
#define ll long long
#define RG register
#define MAX 2222
inline int read()
{
RG int x=0,t=1;RG char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=-1,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return x*t;
}
int K,m,n,ans=1e9;
int g[MAX][MAX];
int sl[MAX][MAX],sr[MAX][MAX];
int Work1(int up)
{
int l1=1,l2=n,r1=1,r2=m,ret=0,ss;
while(l1<=l2&&r1<=r2)
{
++ret;
ss=sr[l2][r1]-sr[l1-1][r1];
if(ss<=K){++r1;continue;}
ss=sr[l2][r2]-sr[l1-1][r2];
if(ss<=K){--r2;continue;}
ss=sl[l1][r2]-sl[l1][r1-1];
if(ss<=K&&l1<up){++l1;continue;}
ss=sl[l2][r2]-sl[l2][r1-1];
if(ss<=K){--l2;continue;}
ret=1e9;break;
}
return ret;
}
int Work2(int left)
{
int l1=1,l2=n,r1=1,r2=m,ret=0,ss;
while(l1<=l2&&r1<=r2)
{
++ret;
ss=sl[l1][r2]-sl[l1][r1-1];
if(ss<=K){++l1;continue;}
ss=sl[l2][r2]-sl[l2][r1-1];
if(ss<=K){--l2;continue;}
ss=sr[l2][r1]-sr[l1-1][r1];
if(ss<=K&&r1<left){++r1;continue;}
ss=sr[l2][r2]-sr[l1-1][r2];
if(ss<=K){--r2;continue;}
ret=1e9;break;
}
return ret;
}
int main()
{
freopen("ork.in","r",stdin);
freopen("ork.out","w",stdout);
K=read();m=read();n=read();
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
g[i][j]=read();
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
sl[i][j]=sl[i][j-1]+g[i][j];
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
sr[i][j]=sr[i-1][j]+g[i][j];
for(int i=1;i<=n;++i)
ans=min(ans,Work1(i));
for(int i=1;i<=m;++i)
ans=min(ans,Work2(i));
printf("%d\n",ans);
return 0;
}

最新文章

  1. UOJ#34 FFT模板题
  2. loj 1316(spfa预处理+状压dp)
  3. DSP using MATLAB 示例Example3.23
  4. WampServer服务中MySQL无法正常启动解决方案
  5. View (四)视图状态及重绘流程分析
  6. POJ 1088 滑雪(记忆化搜索)
  7. 机器人走方格 V3
  8. linux打开端口
  9. Linux学习笔记:CentOS安装MySQL
  10. C# 为网络程序添加用户代理
  11. 图片样式 scaleType 属性
  12. 成功启动了Apache却没有启动apache服务器
  13. c语言结构体1之定义
  14. Transform 位置 旋转
  15. KingbaseES的DBLink创建
  16. python 如何在一个for循环中遍历两个列表
  17. React笔记:组件(3)
  18. 很漂亮的PHP验证码(记录)
  19. EXcel vba 获取批注信息
  20. Node json

热门文章

  1. PhpStorm的破解 汉化
  2. 阿里云学习之API网关
  3. python学习:函数传参数
  4. mysql有多条记录的单个字段想存为一个字段显示的方法
  5. shiro进行散列算法操作
  6. Yii2整合AdminLTE后台主题
  7. 修改maven项目jdk版本,并解决Dynamic Web Module 3.1 requires Java 1.7 or newer错误
  8. Flask從入門到入土(三)——Web表單
  9. nyoj222 整数中的1 数位DP
  10. SpringBoot application.yml logback.xml,多环境配置,支持 java -jar --spring.profiles.active