题目链接:https://vijos.org/p/1120

这怕是我打过最水的一道题了,但是这道隶属于普及组难度的题我竟然提交4次才过,这不禁让我有些后怕,所以还是含泪写下这篇博客,用来警示一下自己;

这题半天不A的原因还是因为是细节问题,第一遍打的时候我压根没有分析,只是凭着感觉打了,但是过后就发现有一些if语句没写好,但是在第三次后我卡了比较久

现在终于发现最后一个问题,不禁有点无语,就是我的程序里,假如所有的花生都采摘了就没有输出,因为我的循环是一旦这一株时间来不及采摘,我就return 0;跳程序

所以忽略了最基础的所有花生都采完这一情况

这道题方法很多,因为是普及组的题,很多方法都可以过,我的想法是,记录所有的有花生的点,按照花生个数排个序,然后依次循环,如果剩下的时间可以支持着猴子去采摘当前这棵并且回到路边,那就去采摘这一棵,并在时间上减去到这棵的时间和采摘的时间(不减去回路边的时间),因为在判断时加上回路边是为了给自己一条后路,假设你当前时间满足去当前这棵花生,但是去了就回不去了,那就肯定不能去的,这个就是我的贪心,思想很简单,理解不了随便举个例子就可以了

然后我想强调的是:一定要仔细去考虑,不要因为题简单而松懈,注意情况是否考虑完全,这类的题要考虑的情况大致分三种:可能全部取完,可能一株都取不到,可能取一部分,

然后从时间考虑又分几个类:时间没有变化,时间有剩余,时间花完了

然后就看看这水得一*的代码吧

 #include<cstdio>
#include<algorithm>
#include<cstdlib>
#define maxn 25
using namespace std;
struct node{
int x,y,val,time;
}e[maxn*maxn];
int n,m,t,ans,map[maxn][maxn],tot,sx,sy,d; int comp(const void *a,const void *b){return (*(struct node*)a).val<(*(struct node*)b).val?:-;} int main(){
scanf("%d%d%d",&n,&m,&t);
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
int a;scanf("%d",&a);
if(a>){
tot++;e[tot].x=i;e[tot].y=j;e[tot].val=a;
e[tot].time=e[tot].x;
}
}
}
e[].val=;sx=sy=-;
qsort(e,tot+,sizeof(e[]),comp);
for(int i=;i<=tot;i++){
if(sx==-&&sy==-){
d=e[i].x+;//
}else d=abs(e[i].x-sx)+abs(e[i].y-sy)+;//距离加上采摘时间
if(d+e[i].time<=t){
t-=d;
sx=e[i].x;sy=e[i].y;
ans+=e[i].val;
}else{
t-=e[i-].time;
printf("%d",ans);return ;
}
}
printf("%d",ans);
}

[vijos1120]花生采摘<贪心>的更多相关文章

  1. noip普及组2004 花生采摘

    花生采摘 描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路的告示牌上贴着一张小小的纸条:"欢迎免费品尝我种的花生!--熊字". 鲁宾逊先生和多多 ...

  2. 【luoguP1086】【2004NOIP-Ua】花生采摘

    P1086 花生采摘 题目描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着一张小小的纸条:“欢迎免费品尝我种的花生!――熊字”. 鲁宾逊先生和多多都 ...

  3. 洛谷——P1086 花生采摘

    P1086 花生采摘 题目描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着一张小小的纸条:“欢迎免费品尝我种的花生!――熊字”. 鲁宾逊先生和多多都 ...

  4. 洛谷 P1086 花生采摘

    P1086 花生采摘 将植株按花生数从大到小排序,然后按排序后的顺序摘,每次摘前计算能否在摘后回到路边,如果能就将ans加上该植株花生数,如果不能就直接输出当前ans并退出. var a:array[ ...

  5. 洛谷 P1086 花生采摘 题解

    P1086 花生采摘 题目描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着一张小小的纸条:"欢迎免费品尝我种的花生!――熊字". ...

  6. P1086 花生采摘

    题目描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着一张小小的纸条:“欢迎免费品尝我种的花生!――熊字”. 鲁宾逊先生和多多都很开心,因为花生正是他 ...

  7. P1086 花生采摘题解

    这道题只是普通的模拟,不是贪心! 重点在于这句话:“然后再找出剩下的植株里花生最多的,去采摘它的花生”. 也就是,你下一个必须找到剩下花生最多的,而不是按照贪心思想来考虑在限定时间内的最优解 那么,应 ...

  8. Luogu 1086 - 花生采摘 - [简单模拟]

    题目链接:https://www.luogu.org/problemnew/show/P1086 题目描述鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着 ...

  9. 洛谷P1086 花生采摘【模拟】

    题目描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着一张小小的纸条:“欢迎免费品尝我种的花生!――熊字”. 鲁宾逊先生和多多都很开心,因为花生正是他 ...

随机推荐

  1. HTML与CSS 开发常用语义化命名

    一.布局❤️ header 头部/页眉:index 首页/索引:logo 标志:nav/sub_nav 导航/子导航:banner 横幅广告:main/content 主体/内容:container/ ...

  2. python数据分析工具 | numpy

    Python中没有提供数组功能,虽然列表可以完成基本的数组功能,但并不是真正的数组,而且在数据量较大时,使用列表的速度回非常慢.因此,Numpy提供了真正的数组功能,以及对数据进行快速处理的函数.Nu ...

  3. Navicat for MySQL12破解

    本文摘抄自:https://blog.csdn.net/zhangli0910/article/details/83785147,https://blog.csdn.net/mmake1994/art ...

  4. vue-cli脚手架目录(2.0)

    vue-cli脚手架目录一览   最近在学习vue,看的稀里糊涂.今天从头开始,把cli配置的vue项目目录和配置文件搞清楚. 先看看整个项目目录结构: 再看看build文件夹下相关文件及目录: co ...

  5. javascript中的中介者模式——迪米特法则

    ”迪米特法则“——最少知识原则,不和陌生人说话,就是说,一个对象应当对其他对象有尽可能少的了解.talk only to your immediate friends.初衷是:降低对象之间的耦合度. ...

  6. Flutter Form表单控件超全总结

    注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 Form.FormField.TextFormField是 ...

  7. Linux系统系统盘扩容

    在Linux学习过程中,可能会遇到根目录存储空间不足的问题,这时候如果只是新增一块硬盘并挂载到某个目录上,还需要将数据转移至新的硬盘中才能缓解存储压力.这种操作未免有些繁琐,那可不可以直接对跟目录进行 ...

  8. Sublime text 3 运行python3

    要在Sublime text3编译器中成功运行 python3,需要在编译器设置中将python3添加至编译器中 新建编译系统 编辑弹出的文件,添加如下内容: { "cmd":[& ...

  9. Java Grammar(二):运算符

    运算符简介 计算机自打诞生以来,用作最多的就是进行计算,而计算离不开运算符,所以运算符在我们的Java语言中的地位举足轻重,我们现在就来了解一下Java给我们提供的运算符. 从运算的元素的个数来区分, ...

  10. nuxt创建项目的步骤

    nuxt创建项目的步骤 1.基本步骤 // 创建package.json依赖管理文件 npm init -y // 在package.json文件中添加运行nuxt的命令,之后npm run dev启 ...