• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

wdgtty

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

最大子段和

include <bits/stdc++.h>

using namespace std;
const int maxn=200005,minn=-0x3f3f3f3f;
int n,arr[maxn];
int maxSubSum(int le, int ri)
{
if(le == ri)
{
return arr[le];
}
int mid=(le+ri) >> 1,leftSum = minn,rightSum = minn,sum = 0;
for(int i=mid;i>=le;i--)
{
sum += arr[i];
if(sum > leftSum)
{
leftSum = sum;
}
}
sum = 0;
for(int i = mid+1;i <= ri;i++)
{
sum += arr[i];
if(sum > rightSum) rightSum=sum;
}
int t = max(maxSubSum(le,mid),maxSubSum(mid+1,ri));
return max(t,leftSum + rightSum);
}
int main()
{
scanf("%d",&n);
for(int i = 1;i <= n;i++)
{
scanf("%d",&arr[i]);
}
printf("%d\n",maxSubSum(1,n));
return 0;
}

posted on 2024-06-22 09:11  到底有没有  阅读(15)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3