链接:https://ac.nowcoder.com/acm/contest/12482/C
来源:牛客网
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
今天小松鼠正在做他的物理作业,大家都知道物理的计算题中总是涉及到大量的单位转换。
而小松鼠只对单纯的数值计算感兴趣,对于单位的计算没有任何兴趣。
于是他找到了作为程序猿/媛的你,希望你可以帮助他计算出单位的运算结果。
小松鼠会告诉你一个单位的计算式子,而你需要告诉他最终单位的运算结果是什么样的。
(大小写敏感,Kg与kg不视作同一个单位)
输入描述:
一行包括一个字符串,保证字符串仅由大小写字母,运算符’*’,’/'构成,长度小于 1000。
输出描述:
你的程序应该输出两行字符串,分别表示化简后的分子与分母
特别的如果分子或者分母最终被化简为空,那么在对应的行上你应该输出 1。
当分子或者分母中包含多个单位时,请用乘号连接,并按字符串的升序输出。
这题自己写的代码通过率只有 92.86%
s = input().split("/")
fz = s[0].split("*")
fm = s[1:]for i in range(len(fm)):if "*" in fm[i]:t = fm[i].split("*")[1:]fm[i] = fm[i].split("*")[0]for j in range(len(t)):fz.append(t[j])for i in fz:if i in fm:fz.remove(i)fm.remove(i)fz.sort()
fm.sort()
z = ""
m = ""
for i in range(len(fz)):if i != len(fz)-1:z += fz[i] + "*"else:z += fz[i]
for i in range(len(fm)):if i != len(fm)-1:m += fm[i] + "*"else:m += fm[i]
if z=="":z = "1"
if m=="":m = "1"
print(z)
print(m)