题目链接:http://codeforces.com/problemset/problem/686/A
题意分析: 水题,输入n,x,之后n行每行输入一个字符ch 和一个数字in 根据加减符号进行对应的加减运算,如果x < in则不能进行减法运算。
求最终x的值以及不能进行减法运算的in数量。
错因: 第一次交错了,这让我很吃惊,怎么看也不觉得写的有问题,回头看了一下数据范围,果断改成long long后过了。 败在long long上已经很多次了,贴上这道题给自己提个醒,不要被同样的问题绊倒多次!
#include<cstdio>
#include<string>
#include<cstdlib>
#include<cmath>
#include<iostream>
#include<cstring>
#include<set>
#include<queue>
const int maxn = 1000000000;
using namespace std;
int num;
int main()
{
int n;
long long x;
scanf("%d%lld",&n,&x);
getchar();
int in;
char ch;
int ans = 0;
for(int i = 0; i < n; i++)
{
scanf("%c%d",&ch,&in);
getchar();
// cout << "ch == " << ch << endl;
if(ch == '+')
x += in;
else if(ch == '-')
{
if(x < in)
{
ans++;
}
else
{
x -= in;
}
}
}
printf("%lld %d\n",x,ans);
return 0;
}