#D8341. Omkar and Waterslide

    ID: 6928 Type: Default 2000ms 256MiB

Omkar and Waterslide

Omkar and Waterslide

Omkar is building a waterslide in his water park, and he needs your help to ensure that he does it as efficiently as possible.

Omkar currently has n supports arranged in a line, the i-th of which has height a_i. Omkar wants to build his waterslide from the right to the left, so his supports must be nondecreasing in height in order to support the waterslide. In 1 operation, Omkar can do the following: take any contiguous subsegment of supports which is nondecreasing by heights and add 1 to each of their heights.

Help Omkar find the minimum number of operations he needs to perform to make his supports able to support his waterslide!

An array b is a subsegment of an array c if b can be obtained from c by deletion of several (possibly zero or all) elements from the beginning and several (possibly zero or all) elements from the end.

An array b_1, b_2, ..., b_n is called nondecreasing if b_i≤ b_{i+1} for every i from 1 to n-1.

Input

Each test contains multiple test cases. The first line contains the number of test cases t (1 ≤ t ≤ 100). Description of the test cases follows.

The first line of each test case contains an integer n (1 ≤ n ≤ 2 ⋅ 10^5) — the number of supports Omkar has.

The second line of each test case contains n integers a_{1},a_{2},...,a_{n} (0 ≤ a_{i} ≤ 10^9) — the heights of the supports.

It is guaranteed that the sum of n over all test cases does not exceed 2 ⋅ 10^5.

Output

For each test case, output a single integer — the minimum number of operations Omkar needs to perform to make his supports able to support his waterslide.

Example

Input

3 4 5 3 2 5 5 1 2 3 5 3 3 1 1 1

Output

3 2 0

Note

The subarray with which Omkar performs the operation is bolded.

In the first test case:

  • First operation:

[5, 3, 2, 5] → [5, 3, 3, 5]

  • Second operation:

[5, 3, 3, 5] → [5, 4, 4, 5]

  • Third operation:

[5, 4, 4, 5] → [5, 5, 5, 5]

In the third test case, the array is already nondecreasing, so Omkar does 0 operations.

inputFormat

Input

Each test contains multiple test cases. The first line contains the number of test cases t (1 ≤ t ≤ 100). Description of the test cases follows.

The first line of each test case contains an integer n (1 ≤ n ≤ 2 ⋅ 10^5) — the number of supports Omkar has.

The second line of each test case contains n integers a_{1},a_{2},...,a_{n} (0 ≤ a_{i} ≤ 10^9) — the heights of the supports.

It is guaranteed that the sum of n over all test cases does not exceed 2 ⋅ 10^5.

outputFormat

Output

For each test case, output a single integer — the minimum number of operations Omkar needs to perform to make his supports able to support his waterslide.

Example

Input

3 4 5 3 2 5 5 1 2 3 5 3 3 1 1 1

Output

3 2 0

Note

The subarray with which Omkar performs the operation is bolded.

In the first test case:

  • First operation:

[5, 3, 2, 5] → [5, 3, 3, 5]

  • Second operation:

[5, 3, 3, 5] → [5, 4, 4, 5]

  • Third operation:

[5, 4, 4, 5] → [5, 5, 5, 5]

In the third test case, the array is already nondecreasing, so Omkar does 0 operations.

样例

3
4
5 3 2 5
5
1 2 3 5 3
3
1 1 1
3

2 0

</p>