★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: http://www.javashuo.com/article/p-geezyvdh-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★css
Given an expression
such as expression = "e + 8 - a + 5"
and an evaluation map such as {"e": 1}
(given in terms of evalvars = ["e"]
and evalints = [1]
), return a list of tokens representing the simplified expression, such as ["-1*a","14"]
html
"2x"
or "-x"
.Expressions are evaluated in the usual order: brackets first, then multiplication, then addition and subtraction. For example, expression = "1 + 2 * 3"
has an answer of ["7"]
.git
The format of the output is as follows:github
"b*a*c"
, only "a*b*c"
."a*a*b*c"
has degree 4.) We write the largest degree terms of our answer first, breaking ties by lexicographic order ignoring the leading coefficient of the term.["-2*a*a*a", "3*a*a*b", "3*b*b", "4*a", "5*c", "-6"]
Examples:express
Input: expression = "e + 8 - a + 5", evalvars = ["e"], evalints = [1] Output: ["-1*a","14"] Input: expression = "e - 8 + temperature - pressure", evalvars = ["e", "temperature"], evalints = [1, 12] Output: ["-1*pressure","5"] Input: expression = "(e + 8) * (e - 8)", evalvars = [], evalints = [] Output: ["1*e*e","-64"] Input: expression = "7 - 7", evalvars = [], evalints = [] Output: [] Input: expression = "a * b * c + b * a * c * 4", evalvars = [], evalints = [] Output: ["5*a*b*c"] Input: expression = "((a - b) * (b - c) + (c - a)) * ((a - b) + (b - c) * (c - a))", evalvars = [], evalints = [] Output: ["-1*a*a*b*b","2*a*a*b*c","-1*a*a*c*c","1*a*b*b*b","-1*a*b*b*c","-1*a*b*c*c","1*a*c*c*c","-1*b*b*b*c","2*b*b*c*c","-1*b*c*c*c","2*a*a*b","-2*a*a*c","-2*a*b*b","2*a*c*c","1*b*b*b","-1*b*b*c","1*b*c*c","-1*c*c*c","-1*a*a","1*a*b","1*a*c","-1*b*c"]
Note:數組
expression
will have length in range [1, 250]
.evalvars, evalints
will have equal lengths in range [0, 100]
.給定一個表達式 expression
如 expression = "e + 8 - a + 5"
和一個求值映射,如 {"e": 1}
(給定的形式爲 evalvars = ["e"]
和 evalints = [1]
),返回表示簡化表達式的標記列表,例如 ["-1*a","14"]
微信
"2x"
或 "-x"
這樣的前導係數或一元運算符 。表達式按一般順序進行求值:先是括號,而後求乘法,再計算加法和減法。例如,expression = "1 + 2 * 3"
的答案是 ["7"]
。app
輸出格式以下:函數
「b*a*c」
這樣的項,只寫 「a*b*c」
。"a*a*b*c"
的次數爲 4。)。咱們先寫出答案的最大次數項,用字典順序打破關係,此時忽略詞的前導係數。["-2*a*a*a", "3*a*a*b", "3*b*b", "4*a", "5*c", "-6"]
。示例:測試
輸入:expression = "e + 8 - a + 5", evalvars = ["e"], evalints = [1] 輸出:["-1*a","14"] 輸入:expression = "e - 8 + temperature - pressure", evalvars = ["e", "temperature"], evalints = [1, 12] 輸出:["-1*pressure","5"] 輸入:expression = "(e + 8) * (e - 8)", evalvars = [], evalints = [] 輸出:["1*e*e","-64"] 輸入:expression = "7 - 7", evalvars = [], evalints = [] 輸出:[] 輸入:expression = "a * b * c + b * a * c * 4", evalvars = [], evalints = [] 輸出:["5*a*b*c"] 輸入:expression = "((a - b) * (b - c) + (c - a)) * ((a - b) + (b - c) * (c - a))", evalvars = [], evalints = [] 輸出:["-1*a*a*b*b","2*a*a*b*c","-1*a*a*c*c","1*a*b*b*b","-1*a*b*b*c","-1*a*b*c*c","1*a*c*c*c","-1*b*b*b*c","2*b*b*c*c","-1*b*c*c*c","2*a*a*b","-2*a*a*c","-2*a*b*b","2*a*c*c","1*b*b*b","-1*b*b*c","1*b*c*c","-1*c*c*c","-1*a*a","1*a*b","1*a*c","-1*b*c"]
提示:
expression
的長度在 [1, 250]
範圍內。evalvars, evalints
在範圍 [0, 100]
內,且長度相同。1 class Solution { 2 //evaluation map 3 static var map:[String:Int] = [String:Int]() 4 5 func basicCalculatorIV(_ expression: String, _ evalvars: [String], _ evalints: [Int]) -> [String] { 6 for i in 0..<evalvars.count 7 { 8 Solution.map[evalvars[i]] = evalints[i] 9 } 10 var i:Int = 0 11 var l:Int = expression.count 12 var stack:[Expression] = [Expression]() 13 var priStack:[Int] = [Int]() 14 var zero:Expression = Expression(0) 15 stack.append(zero) 16 priStack.append(0) 17 var pri:Int = 0 18 19 while (i < l) 20 { 21 var ch:Character = expression[i] 22 if ch.isDigit() 23 { 24 var num:Int = 0 25 while (i < l && expression[i].isDigit()) 26 { 27 num = num * 10 + (expression[i].ascii - 48) 28 i += 1 29 } 30 stack.append(Expression(num)) 31 continue 32 } 33 if ch.isLetter() 34 { 35 var s:String = String() 36 while (i < l && expression[i].isLetter()) 37 { 38 s.append(expression[i]) 39 i += 1 40 } 41 stack.append(Expression(s)) 42 continue 43 } 44 if ch == "(" {pri += 2} 45 if ch == ")" {pri -= 2} 46 if ch == "+" || ch == "-" || ch == "*" 47 { 48 var nowPri:Int = pri 49 if ch == "*" {nowPri += 1} 50 while (!priStack.isEmpty && nowPri <= priStack.last!) 51 { 52 var now:Expression = stack.removeLast() 53 var last:Expression = stack.removeLast() 54 priStack.removeLast() 55 stack.append(last.cal(now)) 56 } 57 stack[stack.count - 1].oper = ch 58 priStack.append(nowPri) 59 } 60 i += 1 61 } 62 63 while (stack.count > 1) 64 { 65 var now:Expression = stack.removeLast() 66 var last:Expression = stack.removeLast() 67 stack.append(last.cal(now)) 68 } 69 70 return stack.last!.toList() 71 } 72 } 73 74 class Term 75 { 76 //the parameter of this term 77 var para:Int = 1 78 //each factor (e.a. a*b*b*c->{a,b,b,c}) 79 var arr:[String] = [String]() 80 81 init(_ x:Int) 82 { 83 self.para = x 84 } 85 86 init(_ s:String) 87 { 88 if Solution.map[s] == nil 89 { 90 arr.append(s) 91 } 92 else 93 { 94 para = Solution.map[s]! 95 } 96 } 97 98 init(_ that:Term) 99 { 100 self.para = that.para 101 self.arr = that.arr 102 } 103 104 func toString() -> String 105 { 106 if para == 0 {return String()} 107 var ans:String = String() 108 for s in arr 109 { 110 ans += ("*" + s) 111 } 112 return String(para) + ans 113 } 114 115 func equals(_ that:Term) -> Bool 116 { 117 if self.arr.count != that.arr.count 118 { 119 return false 120 } 121 for i in 0..<self.arr.count 122 { 123 if self.arr[i] != that.arr[i] 124 { 125 return false 126 } 127 } 128 return true 129 } 130 131 func compareTo(_ that:Term) -> Int 132 { 133 if self.arr.count > that.arr.count {return -1} 134 if self.arr.count < that.arr.count {return 1} 135 for i in 0..<self.arr.count 136 { 137 var x:Int = 0 138 if self.arr[i] > that.arr[i] 139 { 140 x = 1 141 } 142 else if self.arr[i] < that.arr[i] 143 { 144 x = -1 145 } 146 else 147 { 148 x = 0 149 } 150 if x != 0 {return x} 151 } 152 return 0 153 } 154 155 func times(_ that:Term) -> Term 156 { 157 var pro = Term(self.para * that.para) 158 for s in self.arr 159 { 160 pro.arr.append(String(s)) 161 } 162 for s in that.arr 163 { 164 pro.arr.append(String(s)) 165 } 166 pro.arr = pro.arr.sorted(by:>) 167 return pro 168 } 169 } 170 171 class Expression 172 { 173 //Term List 174 var list:[Term] = [Term]() 175 var oper:Character = "+" 176 177 init(_ x:Int) 178 { 179 self.list.append(Term(x)) 180 } 181 182 init(_ s:String) 183 { 184 self.list.append(Term(s)) 185 } 186 187 init(_ l:[Term]) 188 { 189 self.list = l 190 } 191 192 func times(_ that:Expression) -> Expression 193 { 194 var c:[Term] = [Term]() 195 for t1 in self.list 196 { 197 for t2 in that.list 198 { 199 c.append(t1.times(t2)) 200 } 201 } 202 c = combine(c) 203 return Expression(c) 204 } 205 206 func plus(_ that:Expression,_ sgn:Int) -> Expression 207 { 208 var c:[Term] = [Term]() 209 for t in self.list 210 { 211 c.append(Term(t)) 212 } 213 for t in that.list 214 { 215 var t2:Term = Term(t) 216 t2.para = t2.para * sgn 217 c.append(t2) 218 } 219 c = combine(c) 220 return Expression(c) 221 } 222 223 func cal(_ that:Expression) -> Expression 224 { 225 if oper == "+" 226 { 227 return plus(that,1) 228 } 229 if oper == "-" 230 { 231 return plus(that,-1) 232 } 233 return times(that) 234 } 235 236 func toList() -> [String] 237 { 238 var ans:[String] = [String]() 239 for t in list 240 { 241 var s:String = t.toString() 242 if s.count > 0 {ans.append(s)} 243 } 244 return ans 245 } 246 247 func combine(_ a:[Term]) -> [Term] 248 { 249 var a = a 250 a.sort(by:{(t1:Term,t2:Term) -> Bool in 251 return t1.compareTo(t2) < 0}) 252 var c:[Term] = [Term]() 253 for t in a 254 { 255 if c.count != 0 && t.equals(c.last!) 256 { 257 c[c.count - 1].para += t.para 258 } 259 else 260 { 261 c.append(Term(t)); 262 } 263 } 264 return c 265 } 266 } 267 268 //String擴展 269 extension String { 270 //subscript函數能夠檢索數組中的值 271 //直接按照索引方式截取指定索引的字符 272 subscript (_ i: Int) -> Character { 273 //讀取字符 274 get {return self[index(startIndex, offsetBy: i)]} 275 } 276 } 277 278 //Character擴展 279 extension Character 280 { 281 //Character轉ASCII整數值(定義小寫爲整數值) 282 var ascii: Int { 283 get { 284 return Int(self.unicodeScalars.first?.value ?? 0) 285 } 286 } 287 288 func isDigit() -> Bool 289 { 290 if self.ascii > 47 && self.ascii < 58 291 { 292 return true 293 } 294 return false 295 } 296 297 func isLetter() -> Bool 298 { 299 if (self.ascii > 64 && self.ascii < 91) || self.ascii > 96 && self.ascii < 123 300 { 301 return true 302 } 303 return false 304 } 305 }