2022-11-02 Daily Challenge
Today I have done leetcode's November LeetCoding Challenge with cpp
.
November LeetCoding Challenge 2
Description
Minimum Genetic Mutation
A gene string can be represented by an 8-character long string, with choices from 'A'
, 'C'
, 'G'
, and 'T'
.
Suppose we need to investigate a mutation from a gene string start
to a gene string end
where one mutation is defined as one single character changed in the gene string.
- For example,
"AACCGGTT" --> "AACCGGTA"
is one mutation.
There is also a gene bank bank
that records all the valid gene mutations. A gene must be in bank
to make it a valid gene string.
Given the two gene strings start
and end
and the gene bank bank
, return the minimum number of mutations needed to mutate from start
to end
. If there is no such a mutation, return -1
.
Note that the starting point is assumed to be valid, so it might not be included in the bank.
Example 1:
Input: start = "AACCGGTT", end = "AACCGGTA", bank = ["AACCGGTA"] Output: 1
Example 2:
Input: start = "AACCGGTT", end = "AAACGGTA", bank = ["AACCGGTA","AACCGCTA","AAACGGTA"] Output: 2
Example 3:
Input: start = "AAAAACCC", end = "AACCCCCC", bank = ["AAAACCCC","AAACCCCC","AACCCCCC"] Output: 3
Constraints:
start.length == 8
end.length == 8
0 <= bank.length <= 10
bank[i].length == 8
start
,end
, andbank[i]
consist of only the characters['A', 'C', 'G', 'T']
.
Solution
class Solution {
const string chars = "ACGT";
public:
int minMutation(string start, string end, vector<string>& bank) {
if(start == end) return 0;
set<string> valid(bank.begin(), bank.end());
if(!valid.count(end)) return -1;
valid.erase(start);
queue<string> q;
q.push(start);
int step = 0;
while(q.size()) {
int sz = q.size();
while(sz--) {
auto current = q.front();
q.pop();
if(current == end) return step;
for(auto &c : current) {
int origin = c;
for(auto mutation : chars) {
c = mutation;
if(!valid.count(current)) continue;
valid.erase(current);
q.push(current);
}
c = origin;
}
}
step += 1;
}
return -1;
}
};
// Accepted
// 15/15 cases passed (5 ms)
// Your runtime beats 18.63 % of cpp submissions
// Your memory usage beats 81.49 % of cpp submissions (6.5 MB)