HAUTOJ ykc想吃好吃的
来源:互联网 发布:淘宝助理一键放入仓库 编辑:程序博客网 时间:2024/04/28 00:20
1282: ykc想吃好吃的
时间限制: 1 秒 内存限制: 128 MB
提交: 714 解决:93
提交: 714 解决:93
题目描述
一天,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)
第2 - N+1行:N个整数,代表每个店的商品价值 (-10^9 <= S[i] <= 10^9)
输出
czl能买到的最大价值
样例输入
6-2 11 -4 13 5 -2
样例输出
25
提示
水题一道
代码:
#include<iostream>#include<cmath>#include<algorithm>using namespace std;int main(){int n;scanf("%d",&n);int a[50005],b[50005];long long sumx=0;for(int i=0;i<n;i++){scanf("%d",&a[i]);sumx+=a[i];//所有数总和 b[i]=-a[i];//把数反一下 }long long sum1=0,sum2=0,m1=0,m2=0;for(int i=0;i<n;i++){m1+=a[i];//连续正向相加的结果 m2+=b[i];//最大连续负总和(之前变成正变负、负变正了) if(m1<0)m1=0;if(m2<0)m2=0;sum1=max(sum1,m1);//首尾不连时最大连续和 sum2=max(sum2,sumx+m2);//sumx+m2。sumx表示之前加过负数后的总和,m2表示现在多减的负数//避免 1 2 -1000 2 3 这样的情况,所以这样可以排除中间有大负数的情况 }printf("%lld\n",max(sum1,sum2));return 0;}
阅读全文
0 0
- HAUTOJ 1282--ykc想吃好吃的
- HAUTOJ ykc想吃好吃的
- 【hautoj 1282】ykc想吃好吃的 【循环最大字段和】
- 1282: ykc想吃好吃的
- 【HAUT OJ1282】ykc想吃好吃的
- 【最大子序列和 首尾相连】ykc想吃好吃的
- Haut 1282: ykc想吃好吃的(最大连续子段和,首尾相连)
- Haut 1282: ykc想吃好吃的(最大连续子段和,首尾相连)
- 【多校连萌2】D题 ykc想吃好吃的【补题】【最大子段和变形题】
- 清华西门竹鱼坊,吃好吃的。
- 吃了一个好吃的鸡蛋,便想认识这个下蛋的母鸡
- 吃好吃的,买好看的衣服,买大房子~~
- [随笔]_逛街、看电影、玩、吃好吃的
- Qt第一步/好麻烦心好累/我想去吃好吃的/宝宝赐予我力量吧
- 好吃的中国人
- 北京好吃的
- 杭州好吃的
- 好吃的湖南米粉
- java-----内部类
- Spring源码解析-AOP
- Lintcode 二叉树的中序遍历(递归+非递归)
- http请求
- Tkinter学习笔记之Radiobutton选择按钮
- HAUTOJ ykc想吃好吃的
- ionic2热更新
- servlet学习笔记(二)-Cookie
- Java实现-队列中取最大值操作
- Mysql中的复合类型
- FZU
- poj1144(求割点---kuangbin的模板)
- HDU 6153 A Secret【扩展KMP】
- 51 nod 1851 俄罗斯方块