- Step1. Both a[4] and b[4] matches the element c[8], so the true/false grid [4,4] depends on its two neighbors, [4,3] and [3,4].
- Step2. For grid[4,3], a[4] matches c[7], so dependency goes up to [3,3].
- For grid[3,4], both a[3] and b[4] matches c[7], so dependency goes to two neighbors:[2,4] and [3,3]
- Step3. For grid[3,3], b[3] matches c[6], so go left to [3,2]
- For gird [2,4], a[2] matches c[6], so go up to [1,4]
- Step4. For grid[3,2], no matches to c[5], halt (mark false)
- For grid[1,4], a[1] matches c[5], go up to [0,4]
- Step5-9. [0,4]->[0,3]->[0,2]->[0,1]->[0,0]
we find out that [4,4] is true.
Link to the C++ code
/**Update 12/01/2012. This solution is not correct.
85 Answers
Three strings say A,B,C are given to you. Check weather 3rd string is
interleaved from string A and B.
Ex: A="abcd" B="xyz" C="axybczd". answer is yes. o(n)
- learn on August 27, 2012 in United States | Report Duplicate
*/
/**Hints from the comments.
Simple case: pointers to A,B,C are pA,pB,pC. Compare pA (or pB) agains
pC, if matches, ++pA (or ++pB) if none of pA or pB matches, return false
Duplication case: if pA and pB points to the same character, we call it
a conflict. The conflict character is pushed into a FIFO queue, and do
both ++pA and ++pB. When a non-conflict character appears, register it,
pA, for example. Keep searching until pA does not match the next character,
then you HAVE TO consider the conflict queue before using pB.
The queue should have a higher priority than pA/pB, since the queue stores
elemenens BEFORE the pointers.
When the queue is not empty, the match process switching between pA and pB
are forbidden. Since if pA is in process, the queue equivalently stores
elements BEFORE current pB, so skipping the queue directly to pB
is not allowed.
*/
#include <string>
#include <iostream>
#include <vector>
#include <deque>
using namespace std;
class Solution{
public:
bool isInterleave(string const& A, string const& B, string const& C){
if (C.length()!= A.length() + B.length()) return false;
deque<int> conflict_que;
int conflict_flag = 0;
for(int aii = 0, bii = 0, cii = 0; cii < C.length(); ++cii){
if (!conflict_que.empty() && conflict_que.front() == C[cii]){
conflict_que.pop_front();
continue;
}//conflict_que has a match
if (A[aii] == B[bii]){
if (A[aii] == C[cii]){
++aii; ++bii; conflict_flag = 0;
conflict_que.push_back(A[aii]);
continue;
} else return false;//A==B, but no match for C
} else if (A[aii] == C[cii]){
if (!conflict_que.empty() && conflict_flag == 2) return false;
//attemp to jump over conflict_que from B
++aii; conflict_flag = 1;
continue;
} else if (B[bii] == C[cii]){
if (!conflict_que.empty() && conflict_flag == 1) return false;
++bii; conflict_flag = 2;
continue;
} else return false;//no match at all, check queue
}//for cii
return true;
}//isInterleave
};
int main(){
cout<< "Hello"<<endl;
string A("aaa");
string B("abc");
string C("aabcaa");
Solution s;
bool result = s.isInterleave(A,B,C);
cout << result <<endl;
A = "abcd"; B ="xyz"; C = "axybczd";
result = s.isInterleave(A,B,C);
cout<< result <<endl;
return 0;
}
No comments:
Post a Comment