PAT (Advanced Level) 1007 Maximum Subsequence Sum (25 分)
发布日期:2021-06-29 12:22:26 浏览次数:2 分类:技术文章

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

题目概述:

给定数组,求和最大的子序列,输出其最大和以及子序列首尾元素。若全为负数,则输出和为0,以及整个数组的首尾元素。

分析:

这是一道动态规划,但可以不用dp
1.用tempsum表示当前记录的和,若大于sum,则存下目前的最大值以及首尾序号
2.若tempsum < 0,说明这里的记录可以舍弃(因为只会起负作用),并把tempsum置为0,同时tempindex设为i + 1

#include
using namespace std;int main(){
int k; cin >> k; int sum = -1, l = 0, r = k - 1, tempsum = 0, tempindex = 0; vector
vt(k); for(int i = 0; i < k; i++) {
cin >> vt[i]; tempsum += vt[i]; if(tempsum > sum) {
sum = tempsum; l = tempindex; r = i; } else if(tempsum < 0) {
tempindex = i + 1; tempsum = 0; } } if(sum == -1) {
sum = 0; cout << sum << " " << vt[0] << " " << vt[k-1] << endl; return 0; } cout << sum << " " << vt[l] << " " << vt[r] << endl; return 0;}

总结:

1.注意审题,这里是输出首尾元素,而不是序号!!!
2.sum的初始值要设置为-1,这样可以对全部为负数的情况进行识别。

转载地址:https://bridge-killer.blog.csdn.net/article/details/115432899 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:PAT (Advanced Level) 1011 World Cup Betting (20 分)
下一篇:PAT (Advanced Level) 1010 Radix (25 分)

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月15日 20时16分04秒