VK Cup 2012 Round 3 |
---|

Finished |

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

two pointers

*2000

No tag edit access

The problem statement has recently been changed. View the changes.

×
B. Ancient Berland Hieroglyphs

time limit per test

1.5 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputPolycarpus enjoys studying Berland hieroglyphs. Once Polycarp got hold of two ancient Berland pictures, on each of which was drawn a circle of hieroglyphs. We know that no hieroglyph occurs twice in either the first or the second circle (but in can occur once in each of them).

Polycarpus wants to save these pictures on his laptop, but the problem is, laptops do not allow to write hieroglyphs circles. So Polycarp had to break each circle and write down all of its hieroglyphs in a clockwise order in one line. A line obtained from the first circle will be called *a*, and the line obtained from the second one will be called *b*.

There are quite many ways to break hieroglyphic circles, so Polycarpus chooses the method, that makes the length of the largest substring of string *a*, which occurs as a subsequence in string *b*, maximum.

Help Polycarpus — find the maximum possible length of the desired substring (subsequence) if the first and the second circles are broken optimally.

The length of string *s* is the number of characters in it. If we denote the length of string *s* as |*s*|, we can write the string as *s* = *s*_{1}*s*_{2}... *s*_{|s|}.

A substring of *s* is a non-empty string *x* = *s*[*a*... *b*] = *s*_{a}*s*_{a + 1}... *s*_{b} (1 ≤ *a* ≤ *b* ≤ |*s*|). For example, "code" and "force" are substrings of "codeforces", while "coders" is not.

A subsequence of *s* is a non-empty string *y* = *s*[*p*_{1}*p*_{2}... *p*_{|y|}] = *s*_{p1}*s*_{p2}... *s*_{p|y|} (1 ≤ *p*_{1} < *p*_{2} < ... < *p*_{|y|} ≤ |*s*|). For example, "coders" is a subsequence of "codeforces".

Input

The first line contains two integers *l*_{a} and *l*_{b} (1 ≤ *l*_{a}, *l*_{b} ≤ 1000000) — the number of hieroglyphs in the first and second circles, respectively.

Below, due to difficulties with encoding of Berland hieroglyphs, they are given as integers from 1 to 10^{6}.

The second line contains *l*_{a} integers — the hieroglyphs in the first picture, in the clockwise order, starting with one of them.

The third line contains *l*_{b} integers — the hieroglyphs in the second picture, in the clockwise order, starting with one of them.

It is guaranteed that the first circle doesn't contain a hieroglyph, which occurs twice. The second circle also has this property.

Output

Print a single number — the maximum length of the common substring and subsequence. If at any way of breaking the circles it does not exist, print 0.

Examples

Input

5 4

1 2 3 4 5

1 3 5 6

Output

2

Input

4 6

1 3 5 2

1 2 3 4 5 6

Output

3

Input

3 3

1 2 3

3 2 1

Output

2

Note

In the first test Polycarpus picks a string that consists of hieroglyphs 5 and 1, and in the second sample — from hieroglyphs 1, 3 and 5.

Codeforces (c) Copyright 2010-2024 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Apr/18/2024 11:08:05 (g1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|