Loading [MathJax]/jax/output/HTML-CSS/fonts/TeX/fontdata.js

G1. Go Learn! (Easy Version)
time limit per test
5 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

The differences between the easy and hard versions are the constraints on n and the sum of n. In this version, n3000 and the sum of n does not exceed 104. You can only make hacks if both versions are solved.

Well, well, well, let's see how Bessie is managing her finances. She seems to be in the trenches! Fortunately, she is applying for a job at Moogle to resolve this issue. Moogle interviews require intensive knowledge of obscure algorithms and complex data structures, but Bessie received a tip-off from an LGM on exactly what she has to go learn.

Bessie wrote the following code to binary search for a certain element k in a possibly unsorted array [a1,a2,,an] with n elements.

let l = 1
let h = n

while l < h:
let m = floor((l + h) / 2)

if a[m] < k:
l = m + 1
else:
h = m

return l

Bessie submitted her code to Farmer John's problem with m (1mn) tests. The i-th test is of the form (xi,ki) (1x,kn). It is guaranteed all the xi are distinct and all the ki are distinct.

Test i is correct if the following hold:

  1. The xi-th element in the array is ki.
  2. If Bessie calls the binary search as shown in the above code for ki, it will return xi.

It might not be possible for all m tests to be correct on the same array, so Farmer John will remove some of them so Bessie can AC. Let r be the minimum of tests removed so that there exists an array [a1,a2,,an] with 1ain so that all remaining tests are correct.

In addition to finding r, Farmer John wants you to count the number of arrays [a1,a2,,an] with 1ain such that there exists a way to remove exactly r tests so that all the remaining tests are correct. Since this number may be very large, please find it modulo 998244353.

Input

The first line contains a single integer t (1t104) — the number of test cases.

The first line of each test case contains two integers n and m (1mn3000) denoting the number of the array and the number of tests.

The following m lines each contain two integers, describing the tests. The i-th line contains two integers xi and ki (1xi,kin) denoting the index and value of the test. It is guaranteed all xi are distinct and all ki are distinct.

It is guaranteed the sum of n across all test cases does not exceed 104.

Output

For each test case, output two integers, r — the minimum of tests removed so that there exists an array so that all remaining tests are correct, and the number of arrays such that it is possible to remove r tests to make all remaining tests correct modulo 998244353.

Examples
Input
2
5 4
1 1
2 2
4 3
5 4
5 4
5 4
2 5
1 2
3 3
Output
0 1
1 3
Input
2
6 6
1 3
2 5
3 1
4 2
5 4
6 6
30 8
19 22
6 12
12 1
28 27
3 4
14 25
29 14
11 15
Output
3 78
3 839271911
Note

Consider the first example.

In the first test case, the array [1,2,2,3,4] satisfies all m tests, so the minimum number of tests Bessie has to remove is 0. Note that this is also the only array that satisfies all m tests.

In the second test case, the minimum number of tests Bessie has to remove is 1. The only test Bessie can remove is (2,5). If Bessie removes test (2,5), then the arrays satisfying the remaining m1 tests are [2,2,3,1,4], [2,2,3,2,4], [2,2,3,3,4].