import random
from typing import List


class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 268
        self.name='Missing Number'
        self.description='Find the missing number in the given array\n'
        self.url='https://leetcode.com/problems/missing-number/description/'
        self.data="The given intenger 'num' is {}\n"
        self.data="The given array 'num' is {}\n"
        self.question="Find the missing number in the given array\n"
        self.instruction= "Follow the given rule to solve the question.\nrule: "
        self.rule='''
    def missingNumber(self, nums: List[int]) -> int:
        nums.sort()
        k=0
        lenth=len(nums)
        while k<lenth:
            if k!=nums.pop(0):
                return k
            else:
                k+=1
        return k
'''
        self.innitialize='''
1.Innitialize nums,k,lenth
```
nums={0}
k=0
lenth=len(nums)
```
lenth={1}
2.Main loops
'''
        self.iteartion_2_1_enter='''
2.1 one iteration
```
while k<lenth:
```
k={0}<lenth={1}
enter
```
i=nums.pop(0)
```
i={2}
num={3}
'''
        self.iteartion_2_1_do_not_enter='''
2.1 one iteration
```
while k<lenth:
```
k={0}=lenth={1}
do not enter
```
return k
```
So the answer is {0}
'''
        self.IF_statement_enter='''
IF_statement
```
if k!=i:
```
k={0} != i={1}
enter

So the answer is {0}
'''
        self.IF_statement_do_not_enter='''
IF_statement
```
if k!=i:
```
k={0} == i={1}
do not enter
```
else:
    k+=1
```
k={2}
'''
    def gen_data_from_len(self, length: int) -> List:
        '''
        return datapoint of given length
        '''
        data=[i for i in range(length)]
        data.pop(random.randint(1,length-1))
        data.reverse()
        return data
    def rfft_IO(self, nums: List[int]) -> int:
        '''
        data: a datapoint from gen_data_from_len
        return rfft input-output of given data
        '''
        input=self.question+self.data.format(nums)+self.instruction+self.rule
        output="Q:Give an array 'nums' containing n distinct numbers in the range [0, n], return the only number in the range that is missing from the array."
        nums.sort()
        k=0
        lenth=len(nums)
        output+=self.innitialize.format(nums,lenth)
        while k<lenth:
            i=nums.pop(0)
            output+=self.iteartion_2_1_enter.format(k,lenth,i,nums)
            if k!=i:
                output+=self.IF_statement_enter.format(k,i)
                return {"output":output,
                "input":input,
                "answer":k}
            else:
                output+=self.IF_statement_do_not_enter.format(k,i,k+1)
                k+=1
        output+=self.iteartion_2_1_do_not_enter.format(k,lenth)
        answer=k
        return {"output":output,
                "input":input,
                "answer":answer}