import random


class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 890
        self.name = 'Find and Replace Pattern'
        self.description = 'Try to find whether a word in a list matches a given pattern'
        self.url='https://leetcode.com/problems/find-and-replace-pattern/description/'
        self.question='''Q:Try to find whether a word in a list matches a given pattern.\n'''
        self.instruction='''Follow the given rule to solve this problem.\nrule:\n'''
        self.data="The given list is {0} and the pattern is {1}.\n"""
        self.rule='''
def findAndReplacePattern(self, words, pattern: str) -> List[str]:
    r=[]
    d0={}
    p0=[]
    c=0
    while pattern:
        i=pattern.pop(0)
        if i not in d0:
            c+=1
            d0[i]=c
            p0.append(c)
        else:
            p0.append(d0[i])
    while words:
        w=words.pop(0)
        d={}
        p=[]
        c=0
        w_list=[x for x in w]
        while w_list:
            z=w_list.pop(0)
            if z not in d:
                c+=1
                d[z]=c
                p.append(c)
            else:
                p.append(d[z])
        if p==p0:
            r.append(w)
    return r
'''
        self.initialize='''
1.Initialize words,pattern,r,d0,p0,c
```
words={0}
pattern={1}
r=[]
d0={2}
p0=[]
c=0
```
2.Main loops'''
        self.iteration_2_1_enter='''
2.1 One iteration
```
while pattern:
```
pattern={0}
True
enter'''
        self.iteration_2_1_inside='''
```
i=pattern.pop(0)
```
i={0}'''
        self.IF_statement_1_if='''
2.1.1 IF statement
```
if i not in d0:
```
i={0}
d0={1}
i not in d0
enter'''
        self.IF_statement_1_inside='''
```
c+=1
```
c={0}+1={1}
```
d0[i]=c
```
d0={2}
```
p0.append(c)
```
p0={3}
'''
        self.IF_statement_1_else='''
2.1.1 IF statement
```
if i not in d0:
```
i={0}
d0={1}
i in d0
do not enter
```
else:
    p0.append(d0[i])
```
d0[i]={2}
p0={3}
'''
        self.iteration_2_1_do_not_enter='''
2.1 One iteration
```
while pattern:
```
pattern={0}
False
do not enter'''
        self.iteration_2_2_enter='''
2.2 One iteration
```
while words:
```
words={0}
True
enter'''
        self.iteration_2_2_inside='''
```
w=words.pop(0)
```
w={0}
```
d={1}
p=[]
c=0
w_list=[x for x in w]
```
w_list={2}
'''
        self.iteration_2_2_1_enter='''
2.2.1 One iteration
```
while w_list:
```
w_list={0}
True
enter'''
        self.iteration_2_2_1_inside='''
```
z=w_list.pop(0)
```
z={0}
```
'''
        self.IF_statement_2_if='''
2.2.1.1 IF statement
```
if z not in d:
```
z={0}
d={1}
z not in d
enter'''
        self.IF_statement_2_if_inside='''
```
c+=1
```
c={0}+1={1}
```
d[z]=c
```
d={2}
```
p.append(c)
```
p={3}
'''
        self.IF_statement_2_else='''
2.2.1.1 IF statement
```
if z not in d:
```
z={0}
d={1}
z in d
do not enter
```
else:
    p.append(d[z])
```
d[z]={2}
p={3}
'''
        self.iteration_2_2_1_do_not_enter='''
2.2.1 One iteration
```
while w_list:
```
w_list={0}
False
do not enter'''
        self.iteration_2_2_do_not_enter='''
2.2 One iteration
```
while words:
```
words={0}
False
do not enter

So the answer is {1}

'''
        self.IF_statement_2_2_1_if='''
2.2.1 IF statement
```
if p==p0:
```
p={0}
p0={1}
p==p0
enter
```
r.append(w)
```
w={2}
r={3}
'''
        self.IF_statement_2_2_1_do_not_enter='''
2.2.1 IF statement
```
if p==p0:
```
p={0}
p0={1}
p!=p0
do not enter
'''
    def gen_data_from_len(self,length):
        pattern=[]
        for i in range(length//2):
            pattern.append(chr(random.randint(97,100)))
        words=[]
        for i in range(length):
            word=[]
            k=random.randint(0,5)
            for j in range(length//2):               
                word.append(chr(random.randint(97+k,100+k)))
            words.append(word)
        return (words,pattern)
    def rfft_IO(self, ttmp) :
        words, pattern = ttmp
        input=self.question+self.data.format(words,pattern)+self.instruction+self.rule
        r=[]
        d0={}
        p0=[]
        c=0
        output=self.question+self.data+self.initialize.format(words,pattern,d0)
        while pattern:
            output+=self.iteration_2_1_enter.format(pattern)
            i=pattern.pop(0)
            output+=self.iteration_2_1_inside.format(i)              
            if i not in d0:
                output+=self.IF_statement_1_if.format(i,d0)
                c+=1
                d0[i]=c
                p0.append(c)
                output+=self.IF_statement_1_inside.format(c-1,c,d0,p0)
            else:
                p0.append(d0[i])
                output+=self.IF_statement_1_else.format(i,d0,d0[i],p0)
        output+=self.iteration_2_1_do_not_enter.format(pattern)
        while words:
            output+=self.iteration_2_2_enter.format(words)
            w=words.pop(0)
            d={}
            p=[]
            c=0
            w_list=[x for x in w]
            output+=self.iteration_2_2_inside.format(w,d,w_list)
            while w_list:
                output+=self.iteration_2_2_1_enter.format(w_list)
                z=w_list.pop(0) 
                output+=self.iteration_2_2_1_inside.format(z)           
                if z not in d:
                    output+=self.IF_statement_2_if.format(z,d)
                    c+=1
                    d[z]=c
                    p.append(c)
                    output+=self.IF_statement_2_if_inside.format(c-1,c,d,p)
                else:
                    p.append(d[z])
                    output+=self.IF_statement_2_else.format(z,d,d[z],p)
            output+=self.iteration_2_2_1_do_not_enter.format(w_list)

            if p==p0:                 
                r.append(w)
                output+=self.IF_statement_2_2_1_if.format(p,p0,w,r)
            else:
                output+=self.IF_statement_2_2_1_do_not_enter.format(p,p0)
        output+=self.iteration_2_2_do_not_enter.format(words,r)
        return {"input":input,"output":output,"answer":r}