import random
import string
from typing import Counter


class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 2423  
        self.name = 'Remove Letter To Equalize Frequency'  
        self.description = '''Try to remove one letter from word so that the frequency of every letter present in word is equal.'''
        self.url='https://leetcode.com/problems/remove-letter-to-equalize-frequency/description/'
        self.question='''Q:Try to remove one letter from word so that the frequency of every letter present in word is equal.\n'''
        self.data='''The given word is {}\n'''
        self.instruction='''Follow the given rule to solve the question.\nrule:'''
        self.rule='''
    def equalFrequency(self, word: str) -> bool:
        lenth=len(word)
        iteration_time=0
        while iteration_time<lenth:
            new_word=word[:iteration_time]+word[iteration_time+1:]
            cnt=Counter(new_word)
            cnt_list=cnt.values()
            word_set=set(cnt_list)
            iteration_time+=1
            if len(word_set)==1:
                return True
            else:
                pass
        return False
        '''
        
        self.initialize='''
1.Initialize lenth,iteration_time,word
```
lenth=len(word)
iteration_time=0
word={0}
```
lenth={1}

2.Main loops
```
'''
        self.iteration_2_1_enter='''
2.1 One iteration
```
while iteration_time<lenth:
```
iteration_time={0}
lenth={1}
iteration_time<lenth
enter
```
new_word=word[:iteration_time]+word[iteration_time+1:]
```
new_word={2}
```
cnt=Counter(new_word)
```
cnt={3}
```
cnt_list=cnt.values()
```
cnt_list={4}
```
word_set=set(cnt_list)
```
word_set={5}
```
iteration_time+=1
```
iteration_time={0}+1={6}
'''
        self.iteration_2_1__do_not_enter='''
2.1 One iteration
```
while iteration_time<lenth:
```
iteration_time={0}
lenth={1}
iteration_time=lenth
do not enter

So the answer is False
'''
        self.IF_statement_enter='''
IF_statement
```
if len(word_set)==1:
```
len(word_set)={0}
enter
```
return True
```
So the answer is True
'''
        self.IF_statement_do_not_enter='''
IF_statement
```
if len(word_set)==1:
```
len(word_set)={0}
do not enter
```
else:
    pass'''
    def gen_data_from_len(self,length)->str:
        '''
        return datapoint of given length
        '''
        letters = string.ascii_lowercase
        return ''.join(random.choice(letters) for _ in range(length))
    def rfft_IO(self, word: str) -> bool:
        '''
        data: a datapoint from gen_data_from_len
        return rfft input-output of given data
        '''
        input=self.question+self.data.format(word)+self.instruction+self.rule
        lenth=len(word)
        iteration_time=0
        output=self.question+self.initialize.format(word,lenth)
        while iteration_time<lenth:
            new_word=word[:iteration_time]+word[iteration_time+1:]
            cnt=Counter(new_word)
            cnt_list=cnt.values()
            word_set=set(cnt_list)
            iteration_time+=1
            output+=self.iteration_2_1_enter.format(iteration_time-1,lenth,new_word,cnt,cnt_list,word_set,iteration_time)
            if len(word_set)==1:
                output+=self.IF_statement_enter.format(len(word_set))
                return {"input":input,
                        "output":output,
                        "answer":True
                        }
            else:
                output+=self.IF_statement_do_not_enter.format(len(word_set))
                pass
        output+=self.iteration_2_1__do_not_enter.format(iteration_time,lenth)
        return {"input":input,
                "output":output,
                "answer":False}