
import numpy as np
import random
from prompt import Prompt
from copy import deepcopy

class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 344  
        self.name =  'string_reverse'  
        self.description = "reverse a string without extra memory"  
        self.url = "https://leetcode.com/problems/reverse-string/description/"
         
        self.rule = '''
def string_reverse(string):
# Initialize variables
i = 0
# Main loop
while i < len(s)//2:
    s[i], s[-i-1] = s[-i-1], s[i]
    i+=1
return s'''
        self.initialize = '''
1. Initialize variables
s = {}
```
i = 0
```
2. Main loop'''
        self.one_iteration_2_1 = '''
2.1 one iteration
```
while i < len(s)//2:
```
len(s) = {}
len(s)//2 = {}
i = {} < len(s)//2 = {}
enter
```
s[i], s[-i-1] = s[-i-1], s[i]
```
s = {}
i = {}
s[i] = {}
s[-i-1] = {}
s[i], s[-i-1] = s[-i-1], s[i] = {}, {}
```
i+=1
```
i = {}
i = i + 1 = {}'''
        self.complete_loop = '''
2.1 one iteration
```
while i < len(s)//2:
```
len(s) = {}
len(s)//2 = {}
i = {} = len(s)//2 =  {}
do not enter'''
        self.return_result = '''
3. Return Result
```
return s
```
s = {}
So the answer is {}.'''

    def gen_data_from_len(self, length: int) -> dict:
        string = random.choices(['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', 'self', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'], k=length)
        question = f'An string s is {string}, reverse it without any extra memory.'
        gt = string[::-1]
        return {"question": question,
                "gt": gt,
                "string": string}
        '''
        return datapoint of given length
        
        return {...}
        '''
            
        
    def rfft_IO(self, data: dict) -> dict:
        instruction = "Follow the given rule to solve the question.\nrule:"
        '''
        data: a datapoint from gen_data_from_len
        return rfft input-output of given data
        
        return {"input": rfft_input,
                "output": rfft_output,
                "answer": ground_truth_answer}
        '''
        rule = self.rule
        input = instruction + rule + "\n\nQ: " + data["question"]
        # rfft output
        string = data["string"]
        output = self.initialize.format(string)
        i = 0
        while i < len(string)//2:
            output += self.one_iteration_2_1.format(len(string), len(string)//2, i, len(string)//2, string, i, string[i], string[-i-1], string[-i-1], string[i], i, i+1)
            string[i], string[-i-1] = string[-i-1], string[i]
            i += 1
        output += self.complete_loop.format(len(string), len(string)//2, i, len(string)//2)
        output += self.return_result.format(string, string)
        answer = string
        return {"input": input,
                "output": output,
                "answer": answer}
    
