399.Evaluate Division
===
###### tags: `Medium`,`Array`,`Graph`,`DFS`,`BFS`
[399. Evaluate Division](https://leetcode.com/problems/evaluate-division/)
### 題目描述
You are given an array of variable pairs `equations` and an array of real numbers `values`, where `equations[i] = [Ai, Bi]` and `values[i]` represent the equation `Ai` / `Bi` = `values[i]`. Each `Ai` or `Bi` is a string that represents a single variable.
You are also given some `queries`, where `queries[j]` = `[Cj, Dj]` represents the j^th^ query where you must find the answer for `Cj` / `Dj` = ?.
Return *the answers to all queries.* If a single answer cannot be determined, return `-1.0`.
**Note:** The input is always valid. You may assume that evaluating the queries will not result in division by zero and that there is no contradiction.
### 範例
**Example 1:**
```
Input: equations = [["a","b"],["b","c"]], values = [2.0,3.0], queries = [["a","c"],["b","a"],["a","e"],["a","a"],["x","x"]]
Output: [6.00000,0.50000,-1.00000,1.00000,-1.00000]
Explanation:
Given: a / b = 2.0, b / c = 3.0
queries are: a / c = ?, b / a = ?, a / e = ?, a / a = ?, x / x = ?
return: [6.0, 0.5, -1.0, 1.0, -1.0 ]
```
**Example 2:**
```
Input: equations = [["a","b"],["b","c"],["bc","cd"]], values = [1.5,2.5,5.0], queries = [["a","c"],["c","b"],["bc","cd"],["cd","bc"]]
Output: [3.75000,0.40000,5.00000,0.20000]
```
**Example 3:**
```
Input: equations = [["a","b"]], values = [0.5], queries = [["a","b"],["b","a"],["a","c"],["x","y"]]
Output: [0.50000,2.00000,-1.00000,-1.00000]
```
**Constraints**:
* 1 <= `equations.length` <= 20
* `equations[i].length` == 2
* 1 <= `Ai.length`, `Bi.length` <= 5
* `values.length` == `equations.length`
* 0.0 < `values[i]` <= 20.0
* 1 <= `queries.length` <= 20
* `queries[i].length` == 2
* 1 <= `Cj.length`, `Dj.length` <= 5
* `Ai`, `Bi`, `Cj`, `Dj` consist of lower case English letters and digits.
### 解答
### Reference
[回到題目列表](https://hackmd.io/@Marsgoat/leetcode_every_day)