import numpy as np
import random
from copy import deepcopy

class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 383
        self.name = "Ransom_Note"
        self.description = '''Given two strings ransomNote and magazine, return true if ransomNote can be constructed by using the letters from magazine and false otherwise.'''
        self.url = '''https://leetcode.com/problems/ransom-note/description/'''
        self.rule = '''
def Ransom_Note(ransomNote: str, magazine: str) -> bool:
    magazine_list = list(magazine)
    ransomNote_list = list(ransomNote)
    i = 0
    while i<len(magazine):
        magazine_list_pop = magazine_list.pop()
        if magazine_list_pop in ransomNote_list:
            ransomNote_list.remove(magazine_list_pop)
        else:
            pass
        i += 1
    if len(ransomNote_list) == 0:
        return True
    else:
        return False'''
        self.initialize = '''
1. Initialize list State
```
magazine_list = list(magazine)
```
magazine = '{}'
magazine_list = {}
```
ransomNote_list = list(ransomNote)
```
ransomNote = '{}'
ransomNote_list = {}
```
i = 0
```
2. Main Loop'''
        self.one_iteration_2_1_construct = '''
2.{} one iteration
```
while i<len(magazine):
```
i = {}
len(magazine) = {}
i < len(magazine)
enter
```
magazine_list_pop = magazine_list.pop()
```
magazine_list_pop = '{}'
```
if magazine_list_pop in ransomNote_list:
```
magazine_list_pop in ransomNota_list
enter
```
ransomNote_list.remove(magazine_list_pop)
```
ransomNote_list = ransomNote_list.remove('{}') = {}
```
i += 1
```
i = {}'''
        self.one_iteration_2_1_no_construct = '''
2.{} one iteration
```
while i<len(magazine):
```
i = {}
len(magazine) = {}
i < len(magazine)
enter
```
magazine_list_pop = magazine_list.pop()
```
magazine_list_pop = '{}'
```
if magazine_list_pop in ransomNote_list:
```
magazine_list_pop not in ransomNota_list
not enter
```
else:
    pass
```
```
i += 1
```
i = {}'''
        self.not_enter_loop = '''
2.{} one iteration
```
while i<len(magazine):
```
i = {}
len(magazine) = {}
i >= len(magazine)
not enter'''
        self.return_result_True = '''
3. Return Result
```
if len(ransomNote_list) == 0:
```
len(ransomNote_list) = {}
len(ransomNote_list) == 0
enter
```
return True
```
So the answer is {}.'''
        self.return_result_False = '''
3. Return Result
```
if len(ransomNote_list) == 0:
```
len(ransomNote_list) = {}
len(ransomNote_list) != 0
not enter
```
else:
    return False
```
So the answer is {}.'''

    def gen_data_from_len(self,length: int) -> dict:
        '''
        return datapoint of given length,
        datapoint is a dict of keys including "question","ransomNote","magazine"
        '''
        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']
        magazine = ''.join(random.choices(Alphabet, k=length))
        length_ = random.choice(range(1,10))
        ransomNote = ''.join(random.choices(Alphabet, k=length_))
        question = f"ransomNote = '{ransomNote}',magazine = '{magazine}'.If ransomNote can be constructed by using the letters from magazine?"

        return {"question": question,
                "ransomNote": ransomNote,
                "magazine": magazine}
            
        
    def rfft_IO(self, data: dict) -> dict:
        '''
        data: a datapoint from gen_data_from_len
        return rfft input-output of given data
        '''
        instruction = "Follow the given rule to solve the question.\nrule:"
        rule = self.rule
        qusetion = data["question"]
        input = instruction + rule + "\n\nQ: " + qusetion
        ransomNote = data['ransomNote']
        magazine = data['magazine']
        ransomNote_list = list(ransomNote)
        magazine_list = list(magazine)
        i = 0
        output = self.initialize.format(magazine,magazine_list,ransomNote,ransomNote_list)
        while i<len(magazine):
            magazine_list_pop = magazine_list.pop()
            if magazine_list_pop in ransomNote_list:
                ransomNote_list.remove(magazine_list_pop)
                output += self.one_iteration_2_1_construct.format(i+1,i,len(magazine),magazine_list_pop,magazine_list_pop,ransomNote_list,i+1)
            else:
                output += self.one_iteration_2_1_no_construct.format(i+1,i,len(magazine),magazine_list_pop,i+1)
            i += 1
        if i>=len(magazine):
            output += self.not_enter_loop.format(i,i,len(magazine))
        if len(ransomNote_list) ==  0:
            answer = 'True'
            output += self.return_result_True.format(len(ransomNote_list),answer)
        else:
            answer = 'False'
            output += self.return_result_False.format(len(ransomNote_list),answer)
        return {"input": input,
                "output": output,
                "answer": answer}

if __name__ == "__main__":
    dataset = Dataset_Generator()
    data = dataset.gen_data_from_len(10)
    file = open("tasks/0383.json","w")
    file.write(dataset.rfft_IO(data)['input']+dataset.rfft_IO(data)['output']+dataset.rfft_IO(data)['answer'])
