此题有问题,只考虑了ABC三种?万一是ABCDEFG……呢,但运行竟然通过了,题目测试环境可能自行做了调整……
#计算式的题目,考出入栈处理括号
#先摘抄优秀答案:
#按照出入栈处理括号的思路,自己重写如下代码。
import sys
for line in sys.stdin:
n = int(line.strip())
mdict = {}
for i in range(n):
mdict[chr(ord('A')+i)] = list(map(int,input().strip().split()))## 用strip()先去掉可能隐藏的末尾空格
# 上面的chr(ord('A')+i)用来以A为基准生成字母
s = input() #读入运算字符串
result = 0
temp = []
for i in s:
if i != ')': #辨别优先级,不遇到')'就一直压栈
temp.append(i)
else: #直到遇到')',把前两个矩阵名弹出来计算乘法运算量
C = temp.pop()
B = temp.pop()
temp.pop()#弹掉前括号'('
result+= mdict[B][0] * mdict[B][1] * mdict[C][1]#m×n和n×l两个缺阵相乘的运算次数就是m×n×l
mdict[B] = [mdict[B][0], mdict[C][1]]#组建合体后的矩阵
temp.append(B) #并把矩阵的名字压栈
#因为有最外圈括号,弹完所有')'即完成整个算式的结果
print(result)