514. Freedom Trail LeetCode Solution
In this guide, you will get 514. Freedom Trail LeetCode Solution with the best time and space complexity. The solution to Freedom Trail problem is provided in various programming languages like C++, Java, and Python. This will be helpful for you if you are preparing for placements, hackathons, interviews, or practice purposes. The solutions provided here are very easy to follow and include detailed explanations.
Table of Contents
- Problem Statement
- Complexity Analysis
- Freedom Trail solution in C++
- Freedom Trail solution in Java
- Freedom Trail solution in Python
- Additional Resources
data:image/s3,"s3://crabby-images/b9458/b945849ae42ed3acd7f41cd4c8f1580870e1ecc1" alt="514. Freedom Trail LeetCode Solution 514. Freedom Trail LeetCode Solution image"
Problem Statement of Freedom Trail
In the video game Fallout 4, the quest “Road to Freedom” requires players to reach a metal dial called the “Freedom Trail Ring” and use the dial to spell a specific keyword to open the door.
Given a string ring that represents the code engraved on the outer ring and another string key that represents the keyword that needs to be spelled, return the minimum number of steps to spell all the characters in the keyword.
Initially, the first character of the ring is aligned at the “12:00” direction. You should spell all the characters in key one by one by rotating ring clockwise or anticlockwise to make each character of the string key aligned at the “12:00” direction and then by pressing the center button.
At the stage of rotating the ring to spell the key character key[i]:
You can rotate the ring clockwise or anticlockwise by one place, which counts as one step. The final purpose of the rotation is to align one of ring’s characters at the “12:00” direction, where this character must equal key[i].
If the character key[i] has been aligned at the “12:00” direction, press the center button to spell, which also counts as one step. After the pressing, you could begin to spell the next character in the key (next stage). Otherwise, you have finished all the spelling.
Example 1:
Input: ring = “godding”, key = “gd”
Output: 4
Explanation:
For the first key character ‘g’, since it is already in place, we just need 1 step to spell this character.
For the second key character ‘d’, we need to rotate the ring “godding” anticlockwise by two steps to make it become “ddinggo”.
Also, we need 1 more step for spelling.
So the final output is 4.
Example 2:
Input: ring = “godding”, key = “godding”
Output: 13
Constraints:
1 <= ring.length, key.length <= 100
ring and key consist of only lower case English letters.
It is guaranteed that key could always be spelled by rotating ring.
Complexity Analysis
- Time Complexity: O(kr^2), where k = |\texttt{key}| and r = |\texttt{ring}|
- Space Complexity: O(k)
514. Freedom Trail LeetCode Solution in C++
class Solution {
public:
int findRotateSteps(string ring, string key) {
return dfs(ring, key, 0, {}) + key.length();
}
private:
// Returns the number of rotates of ring to match key[index..n).
int dfs(const string& ring, const string& key, int index,
unordered_map<string, int>&& mem) {
if (index == key.length())
return 0;
// Add the index to prevent duplication.
const string hashKey = ring + to_string(index);
if (const auto it = mem.find(hashKey); it != mem.cend())
return it->second;
int ans = INT_MAX;
// For each ring[i] == key[index], we rotate the ring to match the ring[i]
// with the key[index], then recursively match the newRing with the
// key[index + 1..n).
for (size_t i = 0; i < ring.length(); ++i)
if (ring[i] == key[index]) {
const int minRotates = min(i, ring.length() - i);
const string& newRing = ring.substr(i) + ring.substr(0, i);
const int remainingRotates =
dfs(newRing, key, index + 1, std::move(mem));
ans = min(ans, minRotates + remainingRotates);
}
return mem[hashKey] = ans;
}
};
/* code provided by PROGIEZ */
514. Freedom Trail LeetCode Solution in Java
class Solution {
public int findRotateSteps(String ring, String key) {
Map<String, Integer> mem = new HashMap<>();
return dfs(ring, key, 0, mem) + key.length();
}
// Returns the number of rotates of ring to match key[index..n).
private int dfs(final String ring, final String key, int index, Map<String, Integer> mem) {
if (index == key.length())
return 0;
// Add the index to prevent duplication.
final String hashKey = ring + index;
if (mem.containsKey(hashKey))
return mem.get(hashKey);
int ans = Integer.MAX_VALUE;
// For each ring[i] == key[index], we rotate the ring to match the ring[i]
// with the key[index], then recursively match the newRing with the
// key[index + 1..n).
for (int i = 0; i < ring.length(); ++i)
if (ring.charAt(i) == key.charAt(index)) {
final int minRotates = Math.min(i, ring.length() - i);
final String newRing = ring.substring(i) + ring.substring(0, i);
final int remainingRotates = dfs(newRing, key, index + 1, mem);
ans = Math.min(ans, minRotates + remainingRotates);
}
mem.put(hashKey, ans);
return ans;
}
}
// code provided by PROGIEZ
514. Freedom Trail LeetCode Solution in Python
class Solution:
def findRotateSteps(self, ring: str, key: str) -> int:
@functools.lru_cache(None)
def dfs(ring: str, index: int) -> int:
"""Returns the number of rotates of ring to match key[index..n)."""
if index == len(key):
return 0
ans = math.inf
# For each ring[i] == key[index], we rotate the ring to match the ring[i]
# with the key[index], then recursively match the newRing with the
# key[index + 1..n).
for i, r in enumerate(ring):
if r == key[index]:
minRotates = min(i, len(ring) - i)
newRing = ring[i:] + ring[:i]
remainingRotates = dfs(newRing, index + 1)
ans = min(ans, minRotates + remainingRotates)
return ans
return dfs(ring, 0) + len(key)
# code by PROGIEZ
Additional Resources
- Explore all LeetCode problem solutions at Progiez here
- Explore all problems on LeetCode website here
Happy Coding! Keep following PROGIEZ for more updates and solutions.