P1115 最大子段和(max()函数)

题目:P1115 最大子段和 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n;
signed main(){
	std::ios::sync_with_stdio(false);
	std::cin.tie(NULL);
	cin>>n;
	int a[200020],b[200020];
//求最大值时初始化用INT_MIN,要不然会报错
	int ans=INT_MIN;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		if(i==1) b[i]=a[i];
		//如果一个数加上上一个数,总和减少,就单独取本身,如果总和增大,则取相加之后的数 
		else b[i]=max(a[i],b[i-1]+a[i]);
		//实时更新当前得到的最大序列和 
		ans=max(ans,b[i]);
	}
	cout<<ans;
	return 0; 
}

学到的:

  • 变量之间的灵活赋值
  • 求最大值函数的灵活应用
相关推荐
小樱花的樱花9 分钟前
打造高效记事本:UI设计到功能实现
开发语言·c++·qt·ui
零二年的冬36 分钟前
epoll详解
java·linux·开发语言·c++·链表
坚持编程的菜鸟44 分钟前
The Blocks Problem
数据结构·c++·算法
tankeven1 小时前
HJ171 排座椅
c++·算法
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 39. 组合总和 | C++ 回溯算法与 startIndex 剪枝
c++·算法·leetcode
宵时待雨1 小时前
优选算法专题1:双指针
数据结构·c++·笔记·算法·leetcode
程序员学习随笔1 小时前
深入剖析 std::optional:实现原理、性能优化与安全编程实践
c++·安全·空值
tankeven1 小时前
HJ172 小红的矩阵染色
c++·算法
每日任务(希望进OD版)1 小时前
线性DP、区间DP
开发语言·数据结构·c++·算法·动态规划
charlie1145141912 小时前
嵌入式C++教程实战之Linux下的单片机编程(9):HAL时钟使能 —— 不开时钟,外设就是一坨睡死的硅
linux·开发语言·c++·单片机·嵌入式硬件·c