import numpy as np
import random
from copy import deepcopy

class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 414
        self.name = "Third_Maximum_Number"
        self.description = '''What's the third maximun number in nums?'''
        self.url = '''https://leetcode.com/problems/third-maximum-number/description/'''
        self.rule = '''
def Third_Maximum_Number(nums: list[int]) -> int:
    max_nums = max(nums)
    if len(nums) < 3:
        return max_nums
    a = b = c = float('-inf')
    while nums:
        num = nums.pop(0)
        if num > a:
            c = b
            b = a
            a = num
        elif num > b and num != a:
            c = b
            b = num
        elif num > c and num != a and num != b:
            c = num
    if c != float('-inf'):
        return c
    else:
        return max_nums'''
        self.judegment_in = '''
1. judegment
```
max_nums = max(nums)
```
max_nums = {}
```
if len(nums) < 3:
```
len(nums) = len({}) = {}
len(nums) < 3
enter
```
return max_nums
```
return {}
```

So the answer is {}.'''
        self.judegment_not_in = '''
1. judegment
```
max_nums = max(nums)
```
max_nums = {}
```
if len(nums) < 3:
```
len(nums) = len({}) = {}
len(nums) >= 3
not enter
```
a = b = c = float('-inf')
```
a = b = c = {}

2. main loop'''
        self.the_2_1_iteration_change_first = '''
2.{} interation
```
while nums:
```
nums = {}
enter
```
num = nums.pop(0)
```
num = {}
```
if num > a:
```
num = {}
num > a
enter
```
c = b
```
c = {}
```
b = a
```
b = {}
```
a = num
```
a = {}'''
        self.the_2_1_iteration_change_second = '''
2.{} interation
```
while nums:
```
nums = {}
enter
```
num = nums.pop(0)
```
num = {}
```
if num > a:
```
num = {}
num <= a
not enter
```
elif num > b and num != a:
```
num = {}
num > b and num != a
enter
```
c = b
```
c = {}
```
b = num
```
b = {}'''
        self.the_2_1_iteration_change_third = '''
2.{} interation
```
while nums:
```
nums = {}
enter
```
num = nums.pop(0)
```
num = {}
```
if num > a:
```
num = {}
num <= a
not enter
```
elif num > b and num != a:
```
num = {}
num <= b or num == a
not enter
```
elif num > c and num != a and num != b:
```
num = {}
num > c and num != a and num != b
enter
```
c = num
```
c = {}'''
        self.the_2_1_iteration_not_change = '''
2.{} interation
```
while nums:
```
nums = {}
enter
```
num = nums.pop(0)
```
num = {}
```
if num > a:
```
num = {}
num <= a
not enter
```
elif num > b and num != a:
```
num = {}
num <= b or num == a
not enter
```
elif num > c and num != a and num != b:
```
num = {}
num <= c or num == a or num == b
not enter'''
        self.not_enter_loop = '''
2.{} interation
```
while nums:
```
nums = {}
not enter'''
        self.return_result_third = '''
3. return result
```
if c != float('-inf'):
```
c = {}
c != float('-inf')
enter
```
return c
```

So the answer is {}.'''
        self.return_result_not_third = '''
3. return result
```
if c != float('-inf'):
```
c = {}
c == float('-inf')
not enter
```
else:
    return max_nums
```

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","nums"
        '''
        nums = []
        for i in range(length):
            nums.append(random.choice(range(1,100)))
        question = f'''question: nums = '{nums}'. What's the third maximun number in nums?'''

        return {"question": question,
                "nums": nums}
        
    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
        question = data['question']
        input = instruction + rule + "\n\nQ: " + question
        nums = data['nums']
        max_nums = max(nums)
        a = b = c = float('-inf')
        if len(nums) < 3:
            output = self.judegment_in.format(max_nums,nums,len(nums),max_nums,max_nums)
        else:
            output = self.judegment_not_in.format(max_nums,nums,len(nums),a)
        i = 1
        while nums:
            nums_copy = deepcopy(nums)
            num = nums.pop(0)
            if num > a:
                c = b
                b = a
                a = num
                output += self.the_2_1_iteration_change_first.format(i,nums_copy,num,num,c,b,a)
            elif num > b and num != a:
                c = b
                b = num
                output += self.the_2_1_iteration_change_second.format(i,nums_copy,num,num,num,c,b)
            elif num > c and num != a and num != b:
                c = num
                output += self.the_2_1_iteration_change_third.format(i,nums_copy,num,num,num,num,c)
            else:
                output += self.the_2_1_iteration_not_change.format(i,nums_copy,num,num,num,num)
            i += 1
        if not nums:
            output += self.not_enter_loop.format(i,nums)
        if c!= float('-inf'):
            answer = c
            output += self.return_result_third.format(c,c)
        else:
            answer = max_nums
            output += self.return_result_not_third.format(c,answer)
        return {"input": input,
                "output": output,
                "answer": answer}
    
if __name__ == "__main__":
    dg = Dataset_Generator()
    data = dg.gen_data_from_len(5)
    data = dg.rfft_IO(data)
    file = open("tasks/0414.json", "w")
    file.write(data['input'] + data['output'] + str(data['answer']))