import random


class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 1704  
        self.name = 'Determine if String Halves Are Alike'
        self.description = 'Decide whether the number of vowels in the first half of the string is equal to the number of vowels in the second half of the string.'
        self.url='https://leetcode.com/problems/determine-if-string-halves-are-alike/description'
        self.question='''Decide whether the number of vowels in the first half of the string is equal to the number of vowels in the second half of the string.\n'''
        self.data="The given letter is: {}\n"
        self.instruction="Follow the given rule to solve this problem.\nrule:"
        self.rule='''
def halvesAreAlike(self, s: str) -> bool:
    vowels="aeiouAEIOU"
    lenth=len(s)
    len_2=int(lenth/2)
    latter_sum=0
    former_sum=0
    front=[i for i in s[0:len_2]]
    latter=[j for j in s[len_2:]]
    iteration_time_1=0
    iteration_time_2=0
    while iteration_time_1<len_2:
        a=front.pop(0)
        if a in vowels:
            former_sum+=1
        iteration_time_1+=1
    while iteration_time_2<len_2:
        b=latter.pop(0)
        if b in vowels:
            latter_sum+=1
        iteration_time_2+=1
    if latter_sum==former_sum:
        return True
    else:
        return False
'''
        

        self.initialize='''
1.Initialize all variables
```
s={4}
```
lenth=len(s)
```
lenth={0}
```
len_2=int(lenth/2)
```
len_2={1}
```
vowels="aeiouAEIOU"
latter_sum=0
former_sum=0
front=[i for i in s[0:len_2]]
```
front={2}
```
latter=[j for j in s[len_2:]]
```
latter={3}
```
iteration_time_1=0
iteration_time_2=0
```
2.Main loop
'''
        self.iteration_2_1='''
2.1 One iteration
```
while iteration_time_1<len_2:
```
iteration_time_1={0}
len_2={1}
{0}<{1}
enter
```
a=front.pop(0)
```
a={2}
'''
        self.iteration_2_1_do_not_enter='''
2.1 One iteration
```
while iteration_time_1<len_2:
```
iteration_time_1={0}
len_2={1}
{0}={1}
do not enter
'''
        self.IF_statement_1_enter='''
IF statement 1
```
if a in vowels:
```
a={0}
vowels={1}
a in vowels
enter
```
former_sum+=1
```
former_sum={2}+1={3}
```
iteration_time_1+=1
```
iteration_time={4}+1={5}
'''
        self.IF_statement_1_do_not_enter='''
IF statement 1
```
if a in vowels:
```
a={0}
vowels={1}
a not in vowels
do not enter
```
iteration_time_1+=1
```
iteration_time={2}+1={3}
'''
        self.iteration_2_2='''
2.2 One iteration
```
while iteration_time_2<len_2:
```
iteration_time_2={0}
len_2={1}
{0}<{1}
enter
```
b=latter.pop(0)
```
b={2}
'''
        self.IF_statement_2_enter='''
IF statement 2
```
if b in vowels:
```
b={0}
vowels={1}
b in vowels
enter
```
latter_sum+=1
```
latter_sum={2}+1={3}
```
iteration_time_2+=1
```
iteration_time={4}+1={5}
'''
        self.IF_statement_2_do_not_enter='''
IF statement 2
```
if b in vowels:
```
b={0}
vowels={1}
b not in vowels
do not enter
```
iteration_time_2+=1
```
iteration_time={2}+1={3}
'''
        self.iteration_2_2_do_not_enter='''
2.1 One iteration
```
while iteration_time_2<len_2:
```
iteration_time_2={0}
len_2={1}
{0}={1}
do not enter
'''
        self.IF_statement_3='''
IF statement 3
```
if latter_sum==former_sum:
```
latter_sum={0}
former_sum={1}
{0}={1}
enter

So the former part is equal to the latter part.
'''
        self.IF_statement_3_do_not_enter='''
IF statement 3
```
if latter_sum==former_sum:
```
latter_sum={0}
former_sum={1}
{0}!={1}
do not enter
```
else
```
enter


So the former part is not equal to the latter part.
'''
    def gen_data_from_len(self, length: int) -> str:
        '''
        return datapoint of given length
        '''
        vowels=['a','e','i','o','u','A','E','I','O','U']
        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','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']
        output=[]
        for i in range(0,2*length,2):
            output.append(random.choice(alphabet+vowels))
        return ''.join(output)
    def rfft_IO(self, s: str) -> dict:
        '''
        data: a datapoint from gen_data_from_len
        return rfft input-output of given data
        '''
        input=self.question+self.data.format(s)+self.instruction+self.rule
        
        lenth=len(s)
        len_2=int(lenth/2)
        vowels="aeiouAEIOU"
        latter_sum=0
        former_sum=0
        front=[i for i in s[0:len_2]]
        latter=[j for j in s[len_2:]]
        iteration_time_1=0
        iteration_time_2=0
        output=self.question+self.initialize.format(lenth,len_2,front,latter,s)
        while iteration_time_1<len_2:
            a=front.pop(0)
            output+=self.iteration_2_1.format(iteration_time_1,len_2,a)
            if a in vowels:
                former_sum+=1
                output+=self.IF_statement_1_enter.format(a,vowels,former_sum-1,former_sum,iteration_time_1,iteration_time_1+1)
            iteration_time_1+=1
            output+=self.IF_statement_1_do_not_enter.format(a,vowels,iteration_time_1-1,iteration_time_1)
        output+=self.iteration_2_1_do_not_enter.format(iteration_time_1,len_2)

        while iteration_time_2<len_2:
            b=latter.pop(0)
            output+=self.iteration_2_2.format(iteration_time_2,len_2,b)

            if b in vowels:
                latter_sum+=1
                output+=self.IF_statement_2_enter.format(b,vowels,latter_sum-1,latter_sum,iteration_time_2,iteration_time_2+1)
            iteration_time_2+=1
            output+=self.IF_statement_2_do_not_enter.format(b,vowels,iteration_time_2-1,iteration_time_2)
        output+=self.iteration_2_2_do_not_enter.format(iteration_time_2,len_2)
        if latter_sum==former_sum:
            output+=self.IF_statement_3.format(latter_sum,former_sum)
            return {'input':input,'output':output,'answer':True}
        else:
            output+=self.IF_statement_3_do_not_enter.format(latter_sum,former_sum)
            return {'input':input,'output':output,'answer':False}