CodeForces 1195C Basketball Exercise (线性DP)

简介: CodeForces 1195C Basketball Exercise (线性DP)

CodeForces 1195C Basketball Exercise (线性DP)

传送门

思路:

一眼的dp

dp[i] [j]表示选到第i列时第j行的身高之和(j=0,1)

答案就是max(dp[n] [0],dp[n] [1]);

划分界限为这一列是否选,不选的话从上一列的同一行转移,选的话从上一列的不同行转移。

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define x first 
#define y second 
const int maxn=1e5+10;
ll dp[maxn][2];
pair<ll,ll>p[maxn];
int main(){
  int n;cin>>n;
  for(int i=1;i<=n;i++) cin>>p[i].x;
  for(int i=1;i<=n;i++) cin>>p[i].y;
  dp[1][0]=p[1].x;dp[1][1]=p[1].y;
  for(int i=2;i<=n;i++){
    dp[i][0]=max(dp[i-1][0],dp[i-1][1]+p[i].x);
    dp[i][1]=max(dp[i-1][1],dp[i-1][0]+p[i].y);
  }
  cout<<max(dp[n][0],dp[n][1])<<endl;
  return 0;
} 


目录
相关文章
|
6月前
codeforces 322 B Ciel and Flowers
有红绿蓝三种颜色的画,每种拿三朵可以组成一束花,或者各拿一朵组成花束,告诉你每种花的数目,求出可能组成最多的花束。 如果你的代码过不了,考虑一下 8 8 9这种组合。 因为数据量很大,我的思想就是局部和总体采用不同的策略。
26 0
|
6月前
codeforces 312
A. Whose sentence is it?
26 0
|
6月前
|
C++
codeforces 305 C. Ivan and Powers of Two
我的思路是这样的,由2^a+2^a = 2^(a+1)可知,如果有两个连续的数a,我们可以把他们合并为a+1放入集合中,使集合中没有重复的数,我可以用stl里的set。如果想要满足题目中的要求,集合中必须有最大那个数个元素,缺多少就可以计算出来了。
15 0
|
6月前
codeforces 322 A Ciel and Dancing
有n个男孩和m个女孩,他们要结对跳舞,每对要有一个女孩和一个男孩,而且其中一个要求之前没有和其他人结对,求出最大可以结多少对。
21 0
|
6月前
codeforces 327 A Ciel and Dancing
给你一串只有0和1的数字,然后对某一区间的数翻转1次(0变1 1变0),只翻转一次而且不能不翻转,然后让你计算最多可能出现多少个1。 这里要注意很多细节 比如全为1,要求必须翻转,这时候我们只要翻转一个1就可以了,对于其他情况,我们只要计算区间里面如果0多于1,将其翻转后计算1的总数,然后取最大值。
20 0
C - Rumor CodeForces - 893C
C - Rumor CodeForces - 893C
62 0
Codeforces 833E Caramel Clouds
E. Caramel Clouds time limit per test:3 seconds memory limit per test:256 megabytes input:standard input output:standard out...
1129 0
|
机器学习/深度学习 人工智能 网络架构
Codeforces 706B Interesting drink
B. Interesting drink time limit per test:2 seconds memory limit per test:256 megabytes input:standard input output:standard outp...
1137 0
Codeforces 591B Rebranding
B. Rebranding time limit per test:2 seconds memory limit per test:256 megabytes input:standard input output:standard output ...
829 0