#D4164. Reverse Binary Strings

    ID: 3459 Type: Default 2000ms 256MiB

Reverse Binary Strings

Reverse Binary Strings

You are given a string s of even length n. String s is binary, in other words, consists only of 0's and 1's.

String s has exactly n/2 zeroes and n/2 ones (n is even).

In one operation you can reverse any substring of s. A substring of a string is a contiguous subsequence of that string.

What is the minimum number of operations you need to make string s alternating? A string is alternating if s_i ≠ s_{i + 1} for all i. There are two types of alternating strings in general: 01010101... or 10101010...

Input

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

The first line of each test case contains a single integer n (2 ≤ n ≤ 10^5; n is even) — the length of string s.

The second line of each test case contains a binary string s of length n (s_i ∈ {0, 1}). String s has exactly n/2 zeroes and n/2 ones.

It's guaranteed that the total sum of n over test cases doesn't exceed 10^5.

Output

For each test case, print the minimum number of operations to make s alternating.

Example

Input

3 2 10 4 0110 8 11101000

Output

0 1 2

Note

In the first test case, string 10 is already alternating.

In the second test case, we can, for example, reverse the last two elements of s and get: 0110 → 0101.

In the third test case, we can, for example, make the following two operations:

  1. 11101000 → 10101100;
  2. 10101100 → 10101010.

inputFormat

Input

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

The first line of each test case contains a single integer n (2 ≤ n ≤ 10^5; n is even) — the length of string s.

The second line of each test case contains a binary string s of length n (s_i ∈ {0, 1}). String s has exactly n/2 zeroes and n/2 ones.

It's guaranteed that the total sum of n over test cases doesn't exceed 10^5.

outputFormat

Output

For each test case, print the minimum number of operations to make s alternating.

Example

Input

3 2 10 4 0110 8 11101000

Output

0 1 2

Note

In the first test case, string 10 is already alternating.

In the second test case, we can, for example, reverse the last two elements of s and get: 0110 → 0101.

In the third test case, we can, for example, make the following two operations:

  1. 11101000 → 10101100;
  2. 10101100 → 10101010.

样例

3
2
10
4
0110
8
11101000
0

1 2

</p>