1159A A pile of stones

 

A. A pile of stones

time limit per test

1 second

memory limit per test

256 megabytes

input

standard input

output

standard output

Vasya has a pile, that consists of some number of stones. nn times he either took one stone from the pile or added one stone to the pile. The pile was non-empty before each operation of taking one stone from the pile.

You are given nn operations which Vasya has made. Find the minimal possible number of stones that can be in the pile after making these operations.

Input

The first line contains one positive integer nn — the number of operations, that have been made by Vasya (1≤n≤1001≤n≤100).

The next line contains the string ss, consisting of nn symbols, equal to "-" (without quotes) or "+" (without quotes). If Vasya took the stone on ii-th operation, sisi is equal to "-" (without quotes), if added, sisi is equal to "+" (without quotes).

Output

Print one integer — the minimal possible number of stones that can be in the pile after these nn operations.

Examples

input

Copy

3
---

output

Copy

0

input

Copy

4
++++

output

Copy

4

input

Copy

2
-+

output

Copy

1

input

Copy

5
++-++

output

Copy

3

Note

In the first test, if Vasya had 33 stones in the pile at the beginning, after making operations the number of stones will be equal to 00. It is impossible to have less number of piles, so the answer is 00. Please notice, that the number of stones at the beginning can't be less, than 33, because in this case, Vasya won't be able to take a stone on some operation (the pile will be empty).

In the second test, if Vasya had 00 stones in the pile at the beginning, after making operations the number of stones will be equal to 44. It is impossible to have less number of piles because after making 44 operations the number of stones in the pile increases on 44 stones. So, the answer is 44.

In the third test, if Vasya had 11 stone in the pile at the beginning, after making operations the number of stones will be equal to 11. It can be proved, that it is impossible to have less number of stones after making the operations.

In the fourth test, if Vasya had 00 stones in the pile at the beginning, after making operations the number of stones will be equal to 33.

 

Meaning of the questions: a pile of stones, you can add or take away a piece of stone, a stone if it is taken away, this pile of stones to ensure there is enough stone, then you can add no stone. Now to the operation n times, and a string of length n, + is added, - is reduced, after n times after the operation, it outputs the current number of stones rock heap.

Solution: Analog

python:

n=int(input())
s=input()
ans=0
for i in s:
          if i=='+':ans+=1
          else:ans=max(ans-1,0)
print(ans)

c++: 

#include<bits/stdc++.h>
using namespace std;
int main()
{
    int n,ans=0;
    string s;
    cin>>n;
    cin>>s;
    for(int i=0; i<n; i++)
        if(s[i]=='+') ans++;
        else ans=ans>0?--ans:0;
    cout<<ans<<endl;
    return 0;
}

 

 

 

Published 395 original articles · won praise 126 · Views 200,000 +

Guess you like

Origin blog.csdn.net/memory_qianxiao/article/details/90240440