C. Basketball Exercise

time limit per test

2 seconds

memory limit per test

256 megabytes

Finally, a basketball court has been opened in SIS, so Demid has decided to hold a basketball exercise session. 2⋅n2⋅n students have come to Demid's exercise session, and he lined up them into two rows of the same size (there are exactly nn people in each row). Students are numbered from 11 to nn in each row in order from left to right.

Now Demid wants to choose a team to play basketball. He will choose players from left to right, and the index of each chosen player (excluding the first one taken) will be strictly greater than the index of the previously chosen player. To avoid giving preference to one of the rows, Demid chooses students in such a way that no consecutive chosen students belong to the same row. The first student can be chosen among all 2n2n students (there are no additional constraints), and a team can consist of any number of students.

Demid thinks, that in order to compose a perfect team, he should choose students in such a way, that the total height of all chosen students is maximum possible. Help Demid to find the maximum possible total height of players in a team he can choose.

Input

The first line of the input contains a single integer nn (1≤n≤1051≤n≤105) --- the number of students in each row.

The second line of the input contains nn integers h1,1,h1,2,...,h1,nh1,1,h1,2,...,h1,n (1≤h1,i≤1091≤h1,i≤109), where h1,ih1,i is the height of the ii-th student in the first row.

The third line of the input contains nn integers h2,1,h2,2,...,h2,nh2,1,h2,2,...,h2,n (1≤h2,i≤1091≤h2,i≤109), where h2,ih2,i is the height of the ii-th student in the second row.

Output

Print a single integer --- the maximum possible total height of players in a team Demid can choose.

Examples

Input

Copy

复制代码
5
9 3 5 7 3
5 8 1 4 5

Output

Copy

复制代码
29

Input

Copy

复制代码
3
1 2 9
10 1 1

Output

Copy

复制代码
19

Input

Copy

复制代码
1
7
4

Output

Copy

复制代码
7

Note

In the first example Demid can choose the following team as follows:

In the second example Demid can choose the following team as follows:

解题说明:此题是一道动态规划题,两排运动员的身高,选出运动员使总身高最大(不能出现有两个运动员是连续痛一排的,只能挨着的两个运动员是不同排位的),输出得到的最大总身高,直接按照DP算法进行求解。

cpp 复制代码
#include<stdio.h>
#include<string.h>
long long int max(long long int a, long long int b)
{
	if (a > b)
	{
		return a;
	}
	else
	{
		return b;
	}
}

int main()
{
	int n;
	scanf("%d", &n);
	long long int h[2][100005];
	for (int i = 0; i < n; i++)
	{
		scanf("%lld", &h[0][i]);
	}
	for (int i = 0; i < n; i++)
	{
		scanf("%lld", &h[1][i]);
	}
	long long int dp[3][n];

	memset(dp, 0, sizeof(dp));
	dp[0][0] = h[0][0];
	dp[1][0] = h[1][0];
	dp[2][0] = 0;

	for (int i = 1; i < n; i++)
	{
		dp[0][i] = max(dp[1][i - 1] + h[0][i], dp[2][i - 1] + h[0][i]);
		dp[0][i] = max(dp[0][i], h[0][i]);

		dp[1][i] = max(dp[0][i - 1] + h[1][i], dp[2][i - 1] + h[1][i]);
		dp[1][i] = max(dp[1][i], h[1][i]);

		dp[2][i] = max(dp[0][i - 1], dp[1][i - 1]);
	}
	printf("%lld\n", max(dp[0][n - 1], dp[1][n - 1]));
	return 0;
}
相关推荐
趙卋傑2 分钟前
测试开发场景下常见的 MCP 服务
开发语言·python·测试工具·ai编程
@atweiwei2 分钟前
langchainrust:Rust 版 LangChain 框架(LLM+Agent+RAG)
开发语言·rust·langchain·agent·向量数据库·rag
阿里嘎多学长4 分钟前
2026-04-11 GitHub 热点项目精选
开发语言·程序员·github·代码托管
yugi9878385 分钟前
基于最大信息熵的粒子群优化算法图像分割(MATLAB实现)
开发语言·算法·matlab
yaoxin5211235 分钟前
376. Java IO API - 使用 Globbing 和自定义 Filter 过滤目录内容
java·开发语言·python
菠萝地亚狂想曲13 分钟前
FreeRTOS heap4
c语言·stm32·嵌入式开发
飞翔的SA13 分钟前
全程 Python:无需离开 Python 即可实现光速级 CUDA 加速,无需c++支持
开发语言·c++·python·nvidia·cuda
计算机安禾15 分钟前
【数据结构与算法】第40篇:图论(四):最短路径——Dijkstra算法与Floyd算法
c语言·数据结构·算法·排序算法·哈希算法·图论·visual studio
冰暮流星21 分钟前
javascript之dom访问css
开发语言·javascript·css
北风toto21 分钟前
java进制转换方法
java·开发语言·python