Skip to content

Latest commit

 

History

History

756

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 

We are stacking blocks to form a pyramid. Each block has a color which is a one letter string.

We are allowed to place any color block C on top of two adjacent blocks of colors A and B, if and only if ABC is an allowed triple.

We start with a bottom row of bottom, represented as a single string. We also start with a list of allowed triples allowed. Each allowed triple is represented as a string of length 3.

Return true if we can build the pyramid all the way to the top, otherwise false.

Example 1:

Input: bottom = "BCD", allowed = ["BCG", "CDE", "GEA", "FFF"]
Output: true
Explanation:
We can stack the pyramid like this:
    A
   / \
  G   E
 / \ / \
B   C   D

We are allowed to place G on top of B and C because BCG is an allowed triple.  Similarly, we can place E on top of C and D, then A on top of G and E.

 

Example 2:

Input: bottom = "AABA", allowed = ["AAA", "AAB", "ABA", "ABB", "BAC"]
Output: false
Explanation:
We can't stack the pyramid to the top.
Note that there could be allowed triples (A, B, C) and (A, B, D) with C != D.

 

Constraints:

  • bottom will be a string with length in range [2, 8].
  • allowed will have length in range [0, 200].
  • Letters in all strings will be chosen from the set {'A', 'B', 'C', 'D', 'E', 'F', 'G'}.

Related Topics:
Bit Manipulation, Depth-first Search

Solution 1.

// OJ: https://leetcode.com/problems/pyramid-transition-matrix/
// Author: github.com/lzl124631x
// Time: O(7^B)
// Space: O(A+7^B)
class Solution {
    vector<char> next[7][7] = {};
    vector<string> formNextLevel(string &bottom) {
        vector<string> ans{""};
        for (int i = 1; i < bottom.size(); ++i) {
            auto &n = next[bottom[i - 1] - 'A'][bottom[i] - 'A'];
            vector<string> v;
            for (char c : n) {
                for (auto &s : ans) {
                    if (s.empty() || next[s.back() - 'A'][c - 'A'].size()) v.push_back(s + c);
                }
            }
            swap(v, ans);
        }
        return ans;
    }
    bool dfs(string &bottom) {
        if (bottom.size() == 1) return true;
        for (auto &s : formNextLevel(bottom)) {
            if (dfs(s)) return true;
        }
        return false;
    }
public:
    bool pyramidTransition(string bottom, vector<string>& allowed) {
        for (auto &s : allowed) next[s[0] - 'A'][s[1] - 'A'].push_back(s[2]);
        return dfs(bottom);
    }
};