栈题,将数据一个一个往栈里面放,直到遇到第一个‘)’ ,从‘)’元素往前找,直到第一次遇到‘(’为止,把中间出现的矩阵乘法次数算出来,然后把乘积得到的矩阵放到与‘)’对应的‘(’位置,将其覆盖,直到元素全部放完为止。
代码如下:
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<string>
using namespace std;
int rom[30]= {0},col[30]= {0},k[5]= {0},cpp;
int* multiply(char a,char b)
{
int aa,bb;
aa=a-'A'+1;
bb=b-'A'+1;
if(col[aa]!=rom[bb])
k[3]=1;
else
{
k[3]=0;
k[0]=rom[aa]*col[bb]*col[aa];
k[1]=rom[aa];
k[2]=col[bb];
}
return k;
}
int main()
{
#ifdef test
freopen("sample.txt","r",stdin);
#endif
char mul[1000],c;
int num,name[30]= {0};
memset(name,0,sizeof(name));
memset(mul,0,sizeof(mul));
cin>>num;
for(int i=1; i<=num; i++)
{
cin>>c;
int kk;
kk=c-'A'+1;
cin>>rom[kk]>>col[kk];
}
cin.get();
while(cin>>mul)
{
char stack[500]= {0};
int pp=0,flag=0;cpp=0;
int fp;
int len=strlen(mul),sum=0;
for(int i=0; i<len; i++)
{
flag=0;
int *p;
if(mul[i]!=')')
stack[pp++]=mul[i];
else
{
fp=pp;
while(1)
{
if(stack[fp]=='(')break;
fp--;
}
for(int i=fp+1; i<pp-1; i++)
{
p=multiply(stack[i],stack[i+1]);
flag=p[3];
if(flag==1)
break;
sum+=p[0];
stack[fp]='A'+26+cpp;
rom[27+cpp]=p[1];
col[27+cpp]=p[2];
}
pp=fp+1;
int fct=0;
for(int ii=1; ii<pp; ii++)
if(stack[ii]=='(')
fct=1;
if(fct==0)
cpp++;
}
if(flag==1)
break;
}
if(flag==1)
cout<<"error"<<endl;
else
cout<<sum<<endl;
}
return 0;
}