• CF w1d1 A. A pile of stones


    A. A pile of stones

    Vasya has a pile, that consists of some number of stones. n 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 n 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 n — the number of operations, that have been made by Vasya (1≤n≤100).

    The next line contains the string s, consisting of n symbols, equal to "-" (without quotes) or "+" (without quotes). If Vasya took the stone on i-th operation, si is equal to "-" (without quotes), if added, si is equal to "+" (without quotes).

    Output

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

    Note

    In the first test, if Vasya had 3 stones in the pile at the beginning, after making operations the number of stones will be equal to 0. It is impossible to have less number of piles, so the answer is 0. Please notice, that the number of stones at the beginning can't be less, than 3, 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 0 stones in the pile at the beginning, after making operations the number of stones will be equal to 4. It is impossible to have less number of piles because after making 4 operations the number of stones in the pile increases on 4 stones. So, the answer is 4.

    In the third test, if Vasya had 1 stone in the pile at the beginning, after making operations the number of stones will be equal to 1. 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 0 stones in the pile at the beginning, after making operations the number of stones will be equal to 3.

    #include<iostream>
    #include<string>
    using namespace std;
    int main()
    {
    	int n,mark,ans=0;
    	string s;
    	cin>>n;
    	cin>>s;
    	if(s[0]=='+'){
    		for(int i=0;i<s.size();i++){
    			if(s[i]=='+')ans++;
    			if(s[i]=='-'&&ans>=1)ans--;
    		}
    	}
    	else
    	{
    		for(int i=0;i<s.size();i++)if(s[i]!='-'){
    			mark=i;
    			break;
    		}
    		for(int i=mark;i<s.size();i++){
    			if(s[i]=='+')ans++;
    			if(s[i]=='-'&&ans>=1)ans--;
    		}
    	}
    	cout<<ans;
    	return 0;
    } 
    
  • 相关阅读:
    网页链接在 什么时候 进行跳转到哪里?
    word中那些重要但是被人忽略的快捷键和长word文档的跳转
    如何在editplus中配置ctags?
    winsow xp不能安装软件, 提示"中断" 是因为设置了 软件限制策略
    firefox的plugin-container.exe进程如何关闭?
    thinkphp的url地址区分大小写?
    thinkphp单入口和多入口的访问方法
    什么时候使用tab键来对齐代码和代码的风格
    该不该用inline-block取代float? inline和float的区别?
    cad中关于点样式点的绘制
  • 原文地址:https://www.cnblogs.com/LiangYC1021/p/12656062.html
Copyright © 2020-2023  润新知