Cod sursa(job #591213)

Utilizator HoriaClementHoriaC HoriaClement Data 23 mai 2011 10:36:55
Problema Evaluarea unei expresii Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.92 kb
#include <fstream>

using namespace std;

int poz=0;
char s[100002];

ifstream in("evaluare.in");
ofstream out("evaluare.out");

int termen(),expresie(),factor();


int expresie()
{
	int val=termen();
	while(s[poz]=='+' || s[poz]=='-')
	{
		if(s[poz]=='+')
		{
			++poz;
			val+=termen();
		}
		else
		{
			++poz;
			val-=termen();
		}
	}
	return val;
}

int termen()
{
	int val=factor();
	while(s[poz]=='*' || s[poz]=='/')
	{
		if(s[poz]=='*')
		{
			++poz;
			val*=factor();
		}
		else
		{
			++poz;
			val/=factor();
		}
	}
	return val;
}


int factor()
{
	int val=0,semn=1;
	while(s[poz]=='-')
	{
		++poz;
		semn=-semn;
	}
	if(s[poz]=='(')
	{
		++poz;
		val=expresie();
		++poz;
		return semn*val;
	}
	while(s[poz]>='0' && s[poz]<='9')
	{
		val=val*10+s[poz]-'0';
		++poz;
	}
	return val*semn;
}

int main()
{
	in.getline(s,100005);
	out<<expresie();
}