栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

[Acwing|蓝桥杯] 1055. 股票买卖 II 线性dp

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

[Acwing|蓝桥杯] 1055. 股票买卖 II 线性dp

前言

没想到在蓝桥杯的课程找到了 II ,比 IV 和 V简单多了
传送门 :

思路

状态表示 : f [ i ] [ 2 ] f[i][2] f[i][2] 表示当前第 i i i天是否有股票

显然状态计算很简单

    没有股票的时候
    f [ i ] [ 0 ] = m a x ( f [ i − 1 ] [ 1 ] + w [ i ] , f [ i − 1 ] [ 0 ] ) f[i][0] = max(f[i-1][1] +w[i],f[i-1][0]) f[i][0]=max(f[i−1][1]+w[i],f[i−1][0])有股票的时候
    f [ i ] [ 1 ] = m a x ( f [ i − 1 ] [ 0 ] − w [ i ] , f [ i − 1 ] [ 1 ] ) f[i][1] =max(f[i-1][0] -w[i],f[i-1][1]) f[i][1]=max(f[i−1][0]−w[i],f[i−1][1])
CODE
const int N  = 1e5+10;
int f[N][2],a[N];
int n;
void solve()
{
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	memset(f,-0x3f,sizeof f);
	
	f[0][0] = 0;
	
	for(int i=1;i<=n;i++){
		
		f[i][0] = max(f[i-1][1]+a[i],f[i-1][0]);
		
		f[i][1] = max(f[i-1][1],f[i-1][0] - a[i]);
		
	}
	
	cout<
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/744134.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号