[Swift]LeetCode770. 基本計算器 IV | Basic Calculator IV

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(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

  • An expression alternates chunks and symbols, with a space separating each chunk and symbol.
  • A chunk is either an expression in parentheses, a variable, or a non-negative integer.
  • A variable is a string of lowercase letters (not including digits.) Note that variables can be multiple letters, and note that variables never have a leading coefficient or unary operator like "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

  • For each term of free variables with non-zero coefficient, we write the free variables within a term in sorted order lexicographically. For example, we would never write a term like "b*a*c", only "a*b*c".
  • Terms have degree equal to the number of free variables being multiplied, counting multiplicity. (For example, "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.
  • The leading coefficient of the term is placed directly to the left with an asterisk separating it from the variables (if they exist.)  A leading coefficient of 1 is still printed.
  • An example of a well formatted answer is ["-2*a*a*a", "3*a*a*b", "3*b*b", "4*a", "5*c", "-6"] 
  • Terms (including constant terms) with coefficient 0 are not included.  For example, an expression of "0" has an output of [].

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:數組

  1. expression will have length in range [1, 250].
  2. 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。)。咱們先寫出答案的最大次數項,用字典順序打破關係,此時忽略詞的前導係數。
  • 項的前導係數直接放在左邊,用星號將它與變量分隔開(若是存在的話)。前導係數 1 仍然要打印出來。
  • 格式良好的一個示例答案是 ["-2*a*a*a", "3*a*a*b", "3*b*b", "4*a", "5*c", "-6"] 。
  • 係數爲 0 的項(包括常數項)不包括在內。例如,「0」 的表達式輸出爲 []。

示例:測試

輸入: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"]

提示:

  1. expression 的長度在 [1, 250] 範圍內。
  2. evalvars, evalints 在範圍 [0, 100] 內,且長度相同。

一樣的測試用例。
使用【測試用例】單獨執行,執行正確。
input
"(e + 8) * (e - 8)"
[]
[]
 
Output
["1*e*e","-64"]
 
Expected
["1*e*e","-64"]
可是提交時,提示解答錯誤。問題不大。
Input
"(e + 8) * (e - 8)"
[]
[]
 
Output
["-63"]
 
Expected
["1*e*e","-64"]
  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 }
相關文章
相關標籤/搜索