列数不等于B的行数,则乘法无法进行。
例如,A是50*10的,B是10*20的,C是20*5的,则(A(BC))的乘法次数为10*20*5(BC的乘法次数)+ 50*10*5((A(BC))的乘法次数)= 3500。
#include
#include
#include
using namespace std;
struct Matrix{
int a, b;
Matrix(int a=0, int b=0):a(a),b(b){}
}m[26];
stack s;
int main(){
int n;
cin>>n;
for(int i = 0; i < n; i++){
cin>>m[i].a>>m[i].b;
}
string expr;
cin>>expr;
int len = expr.length();
//bool error;
int ans = 0;
for(int i = 0; i < len; i++){
if(isalpha(expr[i])) s.push(m[expr[i] - 'A']);
else if(expr[i] == ')'){
Matrix m2 = s.top(); s.pop();
Matrix m1 = s.top(); s.pop();
//if(m1.b != m2.a){error = true; break;}
ans += m1.a * m1.b * m2.b;
/*
Matrix mm;
mm.a = m1.a;
mm.b = m2.b;
*/
s.push(Matrix(m1.a, m2.b)); // 结构体构造函数
// s.push(mm);
}
}
//if(error) cout<<"error"<