Preparando MOJI

Pluses and Minuses

2000ms 262144K

Description:

You are given a string $$$s$$$ consisting only of characters + and -. You perform some process with this string. This process can be described by the following pseudocode:

res = 0
for init = 0 to inf
cur = init
ok = true
for i = 1 to |s|
res = res + 1
if s[i] == '+'
cur = cur + 1
else
cur = cur - 1
if cur < 0
ok = false
break
if ok
break

Note that the $$$inf$$$ denotes infinity, and the characters of the string are numbered from $$$1$$$ to $$$|s|$$$.

You have to calculate the value of the $$$res$$$ after the process ends.

Input:

The first line contains one integer $$$t$$$ ($$$1 \le t \le 1000$$$) — the number of test cases.

The only lines of each test case contains string $$$s$$$ ($$$1 \le |s| \le 10^6$$$) consisting only of characters + and -.

It's guaranteed that sum of $$$|s|$$$ over all test cases doesn't exceed $$$10^6$$$.

Output:

For each test case print one integer — the value of the $$$res$$$ after the process ends.

Sample Input:

3
--+-
---
++--+-

Sample Output:

7
9
6

Informação

Codeforces

Provedor Codeforces

Código CF1373C

Tags

math

Submetido 0

BOUA! 0

Taxa de BOUA's 0%

Datas 09/05/2023 10:04:10

Relacionados

Nada ainda