1282: ykc想吃好吃的
来源:互联网 发布:xc9536 编程 编辑:程序博客网 时间:2024/04/28 20:57
题目描述
一天,ykc在学校闲的无聊,于是决定上街买点吃的,ykc很懒,本来就不是很像逛街,于是找来了czl帮他买,这里应该有滑稽,而czl也不愿为ykc买东西吃,但是ykc很强势,非让他去买,呢没办法了,然而czl还有很多事要做,没呢么多时间帮ykc,而这条小吃街又很长,有n家店,n有50000这么大,并且这n家店的商品价值有所不同(要知道,商品的价值可能为负,哈哈,很神奇吧,但是czl肯定不会傻到赔钱,所以你懂的),哇,czl要疯了,他不想逛这么久啊,他还有个毛病,他只会连续的逛若干家店,并且由于这条街的店很多,所以肯定不会是一条直线,换句话说就是首尾相连,即第n家店和第一家店是连在一起的,然而ykc希望czl买的东西价值最大,不然就会不开心,于是他就把艰难的任务交给你了,他真的不想浪费时间,你能帮助他吗?
输入
第1行:小吃街的长度N(2 <= N <= 50000)
第2 - N+1行:N个整数,代表每个店的商品价值 (-10^9 <= S[i] <= 10^9)
输出
czl能买到的最大价值
样例输入
6
-2 11 -4 13 5 -2
样例输出
25
解题思路:子段总和=最大子段和+最小子段和。
我们先定义一下:比方说我们从第i个店开始找,把i和i之前的那个店的位置定义为“缺口”。根据题意一共有两种情况;
第一种是不经过缺口的,那么这个环状子段就和普通的线状子段是一样的了。
第二种情况是经过了缺口的,那么就根据上面的公式,最大子段和=子段总和-最小子段和。因为这时最大子段和经过了缺口,所以最小子段和肯定不经过缺口。我们再开一个数组存放原先子段的相反数,用原先求最大子段和的方式可以很容易求出最小子段和。
#include<cstdio>#include<iostream>#include<cstring>#include<cmath>#include<algorithm>using namespace std;long long n;long long a[99999];long long b[99999];int main(){ while(~scanf("%lld",&n)) { long long ans=0,sum=0; for(long long i=0;i<n;i++) { scanf("%lld",&a[i]); ans+=a[i];//求出子段总和 b[i]=-a[i];//存放相反数,用于第二种情况求最小子段和 } long long maxx=0; for(long long i=0;i<n;i++) { sum+=a[i]; if(sum>maxx) maxx=sum; if(sum<0) { sum=0; } }//这是第一种情况, sum=0; long long maxx2=0; for(int i=0;i<n;i++) { sum+=b[i]; if(maxx2<=sum) maxx2=sum; if(sum<0) { sum=0; } }//第二种情况。 printf("%lld\n",max(maxx,maxx2+ans)); } return 0;}
- 1282: ykc想吃好吃的
- HAUTOJ 1282--ykc想吃好吃的
- 【HAUT OJ1282】ykc想吃好吃的
- HAUTOJ ykc想吃好吃的
- 【最大子序列和 首尾相连】ykc想吃好吃的
- 【hautoj 1282】ykc想吃好吃的 【循环最大字段和】
- Haut 1282: ykc想吃好吃的(最大连续子段和,首尾相连)
- Haut 1282: ykc想吃好吃的(最大连续子段和,首尾相连)
- 【多校连萌2】D题 ykc想吃好吃的【补题】【最大子段和变形题】
- 清华西门竹鱼坊,吃好吃的。
- 吃了一个好吃的鸡蛋,便想认识这个下蛋的母鸡
- 吃好吃的,买好看的衣服,买大房子~~
- [随笔]_逛街、看电影、玩、吃好吃的
- Qt第一步/好麻烦心好累/我想去吃好吃的/宝宝赐予我力量吧
- 好吃的中国人
- 北京好吃的
- 杭州好吃的
- 好吃的湖南米粉
- Qt删除layout的控件
- Android View关系图
- 毕业3年的程序员,怎么进BAT | 12000字揭秘阿里连环炮面试(附开发手册)
- Android游戏开发指南<一>背景地图
- 大话数据结构 code 第七章 04邻接表深度和广度遍历DFS_BFS
- 1282: ykc想吃好吃的
- 暴力求解法_枚举排列(生成1~n 的排列,生成可重集的排列,下一个排列)
- 关于JavaScript获取元素背景图url的兼容性问题
- android 虚拟设备的用法
- Android之linux基础教学之一 内存地址
- 初入Django4-User表字段自定义拓展
- kuberetes controller模块代码学习
- Android之linux基础教学之二 总体架构
- 文章标题