Codeforces Round #469 (Div. 2)

本文探讨了一种算法问题,即通过分析两个被拦截的消息来确定它们可能包含的最大文件数量。消息由一系列加密块组成,这些块代表了文件在网络中传输时的分割方式。通过对两组数据进行比较和匹配,可以找出可能的文件数量。

B. Intercepted Message
time limit per test
1 second
memory limit per test
512 megabytes
input
standard input
output
standard output

Hacker Zhorik wants to decipher two secret messages he intercepted yesterday. Yeah message is a sequence of encrypted blocks, each of them consists of several bytes of information.

Zhorik knows that each of the messages is an archive containing one or more files. Zhorik knows how each of these archives was transferred through the network: if an archive consists of k files of sizes l1, l2, ..., lk bytes, then the i-th file is split to one or more blocks bi, 1, bi, 2, ..., bi, mi (here the total length of the blocks bi, 1 + bi, 2 + ... + bi, mi is equal to the length of the file li), and after that all blocks are transferred through the network, maintaining the order of files in the archive.

Zhorik thinks that the two messages contain the same archive, because their total lengths are equal. However, each file can be split in blocks in different ways in the two messages.

You are given the lengths of blocks in each of the two messages. Help Zhorik to determine what is the maximum number of files could be in the archive, if the Zhorik's assumption is correct.

Input

The first line contains two integers nm (1 ≤ n, m ≤ 105) — the number of blocks in the first and in the second messages.

The second line contains n integers x1, x2, ..., xn (1 ≤ xi ≤ 106) — the length of the blocks that form the first message.

The third line contains m integers y1, y2, ..., ym (1 ≤ yi ≤ 106) — the length of the blocks that form the second message.

It is guaranteed that x1 + ... + xn = y1 + ... + ymAlso, it is guaranteed that x1 + ... + xn ≤ 106.

Output

Print the maximum number of files the intercepted array could consist of.

Examples
input
Copy
7 6
2 5 3 1 11 4 4
7 8 2 4 1 8
output
3
input
Copy
3 3
1 10 100
1 100 10
output
2
input
Copy
1 4
4
1 1 1 1
output
1
Note

In the first example the maximum number of files in the archive is 3. For example, it is possible that in the archive are three files of sizes 2 + 5 = 715 = 3 + 1 + 11 = 8 + 2 + 4 + 1 and 4 + 4 = 8.

In the second example it is possible that the archive contains two files of sizes 1 and 110 = 10 + 100 = 100 + 10. Note that the order of files is kept while transferring archives through the network, so we can't say that there are three files of sizes 110 and 100.

In the third example the only possibility is that the archive contains a single file of size 4.



#include<iostream>
#include <stdio.h>  
#include <string.h>  
#define LL long long  
using namespace std;
const int maxn = 1e6;
LL qzh[maxn];
LL QZH[maxn];
int main()
{
	int n, m;
	cin >> n >> m;
	int a[100005];
	int b[100005];
	qzh[0] = 0;
	QZH[0] = 0;
	int x, y;
	//Qzh[0] = 0;
	int sum = 0;
	for (int i = 1; i <= n; ++i)
	{
		cin >> x;
		qzh[i] = qzh[i - 1] + x;
	}
	int tt = 1;
	for (int j = 1; j <= m; ++j)
	{
		cin >> y;
		QZH[j] = QZH[j - 1] + y;
		

	}
	
	if (n == 1 || m == 1) {
		cout << 1 << endl;
		return 0;
	}
	int ans = 0;
	if (n == m) {
		int t1 = 1, t2 = 1;
		for (int i = 1; t1 <= n && t2 <= m; i++)
		{

			if (qzh[t1] == QZH[t2]) {
				ans++;
				t1++;
				t2++;
			}
			else if (qzh[t1] < QZH[t2]) {
				t1++;
			}
			else if (qzh[t1] > QZH[t2]) {
				t2++;
			}
		}
		cout << ans << endl;
	}
	if (n > m||n<m) {
		int t1 = 1, t2 = 1;
		for (int i = 1; t1<=n&&t2<=m; i++) {
			if (qzh[t1] == QZH[t2]) {
				ans++;
				t1++;
				t2++;
			}
			else if (qzh[t1] < QZH[t2]) {
				t1++;
			}
			else if (qzh[t1] > QZH[t2]) {
				t2++;
			}

		}
		cout << ans << endl;
	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值