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.

data structures

divide and conquer

flows

graph matchings

*3400

No tag edit access

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

×
G. Oleg and chess

time limit per test

6.5 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputOleg the bank client solves an interesting chess problem: place on *n* × *n* chessboard the maximum number of rooks so that they don't beat each other. Of course, no two rooks can share the same cell.

Remind that a rook standing in the cell (*a*, *b*) beats a rook standing in the cell (*x*, *y*) if and only if *a* = *x* or *b* = *y*.

Unfortunately (of fortunately?) for Oleg the answer in this problem was always *n*, so the task bored Oleg soon. He decided to make it more difficult by removing some cells from the board. If a cell is deleted, Oleg can't put a rook there, but rooks do beat each other "through" deleted cells.

Oleg deletes the cells in groups, namely, he repeatedly choose a rectangle with sides parallel to the board sides and deletes all the cells inside the rectangle. Formally, if he chooses a rectangle, lower left cell of which has coordinates (*x*_{1}, *y*_{1}), and upper right cell of which has coordinates (*x*_{2}, *y*_{2}), then he deletes all such cells with coordinates (*x*, *y*) that *x*_{1} ≤ *x* ≤ *x*_{2} and *y*_{1} ≤ *y* ≤ *y*_{2}. It is guaranteed that no cell is deleted twice, i.e. the chosen rectangles do not intersect.

This version of the problem Oleg can't solve, and his friend Igor is busy at a conference, so he can't help Oleg.

You are the last hope for Oleg! Help him: given the size of the board and the deleted rectangles find the maximum possible number of rooks that could be placed on the board so that no two rooks beat each other.

Input

The first line contains single integer *n* (1 ≤ *n* ≤ 10000) — the size of the board.

The second line contains single integer *q* (0 ≤ *q* ≤ 10000) — the number of deleted rectangles.

The next *q* lines contain the information about the deleted rectangles.

Each of these lines contains four integers *x*_{1}, *y*_{1}, *x*_{2} and *y*_{2} (1 ≤ *x*_{1} ≤ *x*_{2} ≤ *n*, 1 ≤ *y*_{1} ≤ *y*_{2} ≤ *n*) — the coordinates of the lower left and the upper right cells of a deleted rectangle.

If is guaranteed that the rectangles do not intersect.

Output

In the only line print the maximum number of rooks Oleg can place on the board so that no two rooks beat each other.

Examples

Input

5

5

1 1 2 1

1 3 1 5

4 1 5 5

2 5 2 5

3 2 3 5

Output

3

Input

8

4

2 2 4 6

1 8 1 8

7 1 8 2

5 4 6 8

Output

8

Note

Here is the board and the example of rooks placement in the first example:

Codeforces (c) Copyright 2010-2024 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Apr/18/2024 03:21:27 (k2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|