---恢复内容开始---

Beans

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4826    Accepted Submission(s):
2258

Problem Description
Bean-eating is an interesting game, everyone owns an
M*N matrix, which is filled with different qualities beans. Meantime, there is
only one bean in any 1*1 grid. Now you want to eat the beans and collect the
qualities, but everyone must obey by the following rules: if you eat the bean at
the coordinate(x, y), you can’t eat the beans anyway at the coordinates listed
(if exiting): (x, y-1), (x, y+1), and the both rows whose abscissas are x-1 and
x+1.

Now, how much
qualities can you eat and then get ?

 
Input
There are a few cases. In each case, there are two
integer M (row number) and N (column number). The next M lines each contain N
integers, representing the qualities of the beans. We can make sure that the
quality of bean isn't beyond 1000, and 1<=M*N<=200000.
 
Output
For each case, you just output the MAX qualities you
can eat and then get.
 
Sample Input
4 6
11 0 7 5 13 9
78 4 81 6 22 4
1 40 9 34 16 10
11 22 0 33 39 6
 
Sample Output
242
 
填了一个格子以后他的左右相邻的格子和上下两行的格子就不能再选,我们不妨先从一行入手,假设每一行的最大价值已经得出,我们要做的只是从这些行中挑选出几个使其满足题意且价值最大,
(显然我们可以把每一行的最大价值抽象为一个格子,这样所有的行排成一列抽象为一行!只要再计算一次这“一行”的最大价值就好了!挑选一行之后上下不可挑与挑选一个格子后左右不可再跳显然类似!属于同一个问题)
只考虑左右的情况,根据贪心的原理,显然每一行挑选出的格子与格子的间隔k满足(1<=k<=2),想不通的话手画!
所以我们要计算的问题出现了,就是最大不连续子段和,因为彼此不连续所以间隔至少为1,为何至大为2:(如果超出2的话这两个元素之间还是有元素可以选择,由于全为正数所以不可放过!)
我们用dp[i]表示从i到最后一个元素的最大不连续子段和,则dp[i]=max(a[i]+dp[i+2],dp[i+1])|{dp[n]=a[n],dp[n-1]=max(a[n],a[n-1])}
也可以写成正序:dp[i]=max(a[i]+dp[i-2],dp[i-1])|{dp[1]=a[i]}

#include<bits/stdc++.h>
using namespace std;
int dp[200005];
int h[200005];
int book[200005];
int n,m;
int init(int a[],int len)
{
dp[len]=a[len];
dp[len-1]=max(a[len],a[len-1]);
for(int i=len-2;i>=1;--i){
dp[i]=max(a[i]+dp[i+2],dp[i+1]);
}
return dp[1];
}
int main()
{
int i,j,k;
while(cin>>n>>m){int s1=0,s2=0;
for(i=1;i<=n;++i){
for(j=1;j<=m;++j)
scanf("%d",&h[j]);
book[i]=init(h,m);
}
printf("%d\n",init(book,n));
}
return 0;
}

---恢复内容结束---

hdu2845_最大不连续子段和的更多相关文章

  1. 最大子段和SP1716GSS3 线段树

    前言 spoj需要FQ注册,比较麻烦,大家就在luogu评测吧 题目大意: $n$ 个数,$q$ 次操作 操作$0 _ x_ y$把$A_x$ 修改为$y$ 操作$1 _ l _r$询问区间$[l, ...

  2. 11572 - Unique Snowflakes(贪心,两指针滑动保存子段最大长度)

    Emily the entrepreneur has a cool business idea: packaging and selling snowflakes. She has devised a ...

  3. 最大子段和(c++)

    // 最大子段和.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> using namesp ...

  4. 如何快速找到排好序的数组中最先不连续的数字N

    现在有一大堆自然数组成的小到大数组arr,其中会有123456910  这样就要找到6(最先不连续的数字) 举例:[12356789] 找到3 [012345678] 找到8 第一种:遍历数组判断是否 ...

  5. 一个面试题的解答-----从500(Id不连续)道试题库里随机抽取20道题!

    做一个考试系统的项目,现在从试题库里面随机抽取20道题 比如我题库有500道题(ID不连续).题目出现了,如何解决呢,随机抽取! 1,我们先把500道题的id存进一个长度为500的数组. 2,实现代码 ...

  6. Oracle函数over(),rank()over()作用及用法--分区(分组)求和& 不连续/连续排名

    (1)   函数:  over()的作用及用法:    -- 分区(分组)求和. RANK ( ) OVER ( [query_partition_clause] order_by_clause )D ...

  7. 51Node 1065----最小正子段和

    51Node  1065----最小正子段和 N个整数组成的序列a[1],a[2],a[3],…,a[n],从中选出一个子序列(a[i],a[i+1],…a[j]),使这个子序列的和>0,并且这 ...

  8. 最大M子段和 V2

    51nod1053 这题还是我们熟悉的M子段和,只不过N,M<=50000. 这题似乎是一个堆+链表的题目啊 开始考虑把所有正数负数锁在一起. 比如: 1 2 3 -1 –2 -3 666 缩成 ...

  9. 51nod 循环数组最大子段和

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1050 对于普通的数组,只要求一次最大子段和即可.但是这题是可以循环的,所 ...

随机推荐

  1. Core Java 2

    p267~p270: 1.一个方法不仅需要告诉编译器将要返回什么值, 还要告诉编译器有可能发生什么错误(以便在错误发生时用妥善的方式处理错误). 2.方法应该在首部声明所有可能抛出的异常. 3.方法抛 ...

  2. Jsoup解析网页html

    Jsoup解析网页html 解析网页demo: 利用Jsoup获取截图中的数据信息: html代码片段: <!-- 当前基金档案\计算\定投\开户 start --> <div cl ...

  3. wireshark捕获表达式之Berkeley Packet Filter (BPF) syntax

    就网络抓包来说,绝大部分的情况下,我们都是对特定的ip/端口/协议进行捕获和分析,否则就会有大量的垃圾报文,使得分析和性能低下.大部分的抓包工具都采用BPF语法,具体可参考 http://biot.c ...

  4. 05:ModelForm 数据验证 & 生成html & 数据库操作

    目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ...

  5. 20145122《Java程序设计》第九周学习总结

    教材学习内容总结 1.JDBC代表Java数据库连接,这是一个标准的Java API与数据库无关的与Java编程语言之间的和大多数数据库连接.JDBC API支持两层和三层的处理模式对数据库的访问,但 ...

  6. 车载项目问题解(memset)

    1memset函数解 1.void *memset(void *s,int c,size_t n) 总的作用:将已开辟内存空间 s 的首 n 个字节的值设为值 c.2.例子 #includevoid ...

  7. Asterisk1.8 转码策略分析

    最近在修改asterisk转码和编码协商的问题,发现asterisk的转码策略的选择还是有些问题的(基于1.8.9.3版本).——————————————相关的CLI命令转码路径的调试命令:core ...

  8. Jackson 使用和注意项

    依赖maven: <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId ...

  9. mysql 通过binlog 查看执行日志

    环境:linux deepin15.7   mysql 5.7 1.开启binlog vim /etc/mysql/mysql.conf.d/mysqld.cnf 添加 log_bin = /var/ ...

  10. springmvc-自定义消息转换器

    最近的项目没有用到这个,先把自己自学跑通的例子先帖出来,供自己以后参考吧! 如有不对地方望指出! 一.自定义类实现AbstractHttpMessageConverter package com.dz ...