记录编号 |
128622 |
评测结果 |
AAAAA |
题目名称 |
[NOIP 2000PJ]计算器的改良 |
最终得分 |
100 |
用户昵称 |
Cirno |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
0.001 s |
提交时间 |
2014-10-17 22:44:58 |
内存使用 |
0.32 MiB |
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<cstring>
#include<iomanip>
using namespace std;
char str[1000]={0};
double ans;
int lenth;
char word1;
int getnum(int s,int t)
{
int num=0;
for(int q=s;q<=t;q++)
{
if(num!=0)
num=num*10+(str[q]-'0');
else
num=str[q]-'0';
}
return num;
}
void init()
{
freopen("computer.in","r",stdin);
freopen("computer.out","w",stdout);
scanf("%s",str);
lenth=strlen(str);
for(int j=0;j<lenth;j++)
{
if((str[j]>='a'&&str[j]<='z')||(str[j]>='A'&&str[j]<='Z'))
{word1=str[j];return;}
}
}
int pick(int k)
{
int j;
for(j=k;j<lenth;j++)
if(str[j]=='+'||str[j]=='-'||str[j]=='=')
{
return j;
}
return j;
}
void slove()
{
bool part=0;
double unnum0=0,unnum1=0;
double num0=0,num1=0;
int j;
for(int k=0;k<lenth;k++)
{
if(k-1>0&&str[k-1]=='=')
{part=1;}
if(!part)
{
j=pick(k)-1;
if(str[j]==word1)
{
if(k-1>=0&&str[k-1]=='-')
unnum0-=getnum(k,j-1);
if(k-1>=0&&str[k-1]=='+')
unnum0+=getnum(k,j-1);
if(k-1==-1||(str[k-1]!='+'&&str[k-1]!='-'))
unnum0+=getnum(k,j-1);
}
else
{
if(k-1>=0&&str[k-1]=='-')
num0-=getnum(k,j);
if(k-1>=0&&str[k-1]=='+')
num0+=getnum(k,j);
if(k-1==-1||(str[k-1]!='+'&&str[k-1]!='-'))
num0+=getnum(k,j);
}
k=j+1;
}
if(part)
{
j=pick(k)-1;
if(str[j]==word1)
{
if(str[k-1]=='-')
unnum1-=getnum(k,j-1);
if(str[k-1]=='+')
unnum1+=getnum(k,j-1);
if(str[k-1]!='+'&&str[k-1]!='-')
unnum1+=getnum(k,j-1);
}
else
{
if(str[k-1]=='-')
num1-=getnum(k,j);
if(str[k-1]=='+')
num1+=getnum(k,j);
if(str[k-1]!='-'&&str[k-1]!='+'&&str[k-1]!='=')
num1+=getnum(k,j);
}
k=j+1;
}
}
ans=(num1-num0)/(unnum0-unnum1);
}
void out()
{
cout<<word1<<'='<<setiosflags(ios::fixed)<<setprecision(3)<<ans<<endl;
fclose(stdin);
fclose(stdout);
}
int main()
{
init();
slove();
out();
return 0;
}