import string
import random
class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 242
        self.name='Valid Anagram'
        self.description='Determine whether the one word can be converted into another word through alphabetical order adjustment'
        self.url='https://leetcode.com/problems/valid-anagram/description/'
        self.data="the given data is {0} and {1}\n"
        self.question = "question:Determine whether the one word can be converted into another word through alphabetical order adjustment \n"
        self.instruction = "Follow the given rule to solve the question.\nrule: "
        self.rule = '''
def valid_anagram(self, s: str, t: str) -> bool:
        alphabet=['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z']
        list_s=[]
        list_t=[]
        while alphabet:
            letter=alphabet.pop(0)
            s1=s.count(letter)
            t1=t.count(letter)
            list_s.append(s1)
            list_t.append(t1)
        if list_t==list_s:
            return True
        else:
            return False\n'''
        self.initialize='''
1.Initialize alphabet,list_s,list_t,s,t
```
alphabet=['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z']
list_s=[]
list_t=[]
s='{}'
t='{}'
```
2.Main loops'''
        self.iteration_2_1='''
2.1 one iteration
```
while alphabet:
```
alphabet={0}
enter
```
letter=alphabet.pop(0)
```
letter='{1}'
```
s1=s.count(letter)
```
s1={2}
```
t1=t.count(letter)
```
t1={3}
```
list_s.append(s1)
```
list_s={4}
```
list_t.append(t1)
```
list_t={5}
'''
        self.return_result_yes='''
```
if list_t==list_s:
```
enter
```
position='yes'
```

So the answer is {}.'''
        self.return_result_no='''
```
if list_t!=list_s:
```
enter
```
position='no'
```

So the answer is {}.'''
    def gen_data_from_len(self,lenth):
        letters = string.ascii_lowercase
        arrangement1 = ''.join(random.sample(letters, lenth))
        arrangement2 = ''.join(random.sample(letters, lenth))
        return (arrangement1, arrangement2)
    def rfft_IO(self, ttmp) -> bool:
        s,t=ttmp
        input=self.question+self.instruction+self.rule+self.data.format(s,t)
        output=self.question
        alphabet=['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z']
        list_s=[]
        list_t=[]
        output+=self.initialize.format(s,t)
        while alphabet:
            letter=alphabet.pop(0)
            s1=s.count(letter)
            t1=t.count(letter)
            list_s.append(s1)
            list_t.append(t1)
            output+=self.iteration_2_1.format(alphabet,letter,s1,t1,list_s,list_t)
        if list_t==list_s:
            #if two words could be coonverted
            #enter
            position='yes'
            output+=self.return_result_yes.format(position)
        elif list_t!=list_s:
            #if two words couldn't be coonverted
            position='no'
            output+=self.return_result_no.format(position)

        ans=position
        
        return {"input":input,
                "output":output,
                "answer":ans}