import random


class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 2418  
        self.name = 'Sort the People'  
        self.description = 'A list of names and heights are given.Figure out the order of names by their heights.'
        self.url='https://leetcode.com/problems/sort-the-people/description/'
        self.question='''Q:A list of names and heights are given.Figure out the order of names by their heights.\n'''
        self.data='''names={0}\nheights={1}\n'''
        self.instruction='''Follow the given rule to solve this problem.\nrule:'''
        self.rule='''
def sortPeople(self, names: List[str], heights: List[int]) -> List[str]:
    name_heights=[]
    name_new=[]
    iteration_time=0
    while iteration_time<len(names):
        name_heights+=[[-heights[iteration_time],names[iteration_time]]]
        iteration_time+=1
    name_heights.sort()
    iteration_time_1=0
    while iteration_time_1<len(names):
        name_height=name_heights.pop(0)
        name_new.append(name_height[1])
        iteration_time_1+=1
    return name_new
'''
        self.initialize='''
1.Initialize name,heights,name_heights,name_new,iteration_time,iteration_time_1
```
name={0}
heights={1}
name_heights=[]
name_new=[]
iteration_time=0
iteration_time_1=0
```
2.Main loops
'''
        self.iteration_2_1_enter='''
2.1 One iteration
```
while iteration_time<len(names):
```
iteration_time={0}
len(names)={1}
iteration_time<len(names)
enter
'''
        self.iteration_2_1_enter_inside_1='''
```
name_heights+=[[-heights[iteration_time],names[iteration_time]]]
```
name_heights={0}
```
iteration_time+=1
```
iteration_time={2}+1={1}
'''
        self.iteration_2_1__do_not_enter='''
2.1 One iteration
```
while iteration_time<len(names):
```
iteration_time={0}
len(names)={1}
iteration_time=len(names)
do not enter
```
name_heights.sort(reverse=True)
```
name_heights={2}

'''
        self.iteration_2_2_enter='''
2.2 One iteration
```
while iteration_time_1<len(names):
```
iteration_time_1={0}
len(names)={1}
iteration_time_1<len(names)
enter
'''
        self.iteration_2_2_enter_inside_1='''
```
name_height=name_heights.pop(0)
```
name_height={0}
```
name_new.append(name_height[1])
```
name_new={1}
```
iteration_time_1+=1
```
iteration_time_1={3}+1={2}
'''
        self.iteration_2_2_do_not_enter='''
```
while iteration_time_1<len(names):
```
iteration_time_1={0}
len(names)={1}
iteration_time_1=len(names)
do not enter

So the answer is {2}
'''
    def gen_data_from_len(self,length)->list and list: # type: ignore
        '''
        return datapoint of given length
        '''
        name_list=[]
        height_list=[]

        with open('names.txt','r') as infile:
            names=infile.readlines()
        for i in range(length):
            c=random.randint(0,len(names)-1)
            name_list.append(names[c].strip())
        for i in range(length):
            height_list.append(random.randint(150,200))
        return (name_list,height_list)
    def rfft_IO(self, ttmp) -> list:
        '''
        data: a datapoint from gen_data_from_len
        return rfft input-output of given data
        '''
        names,heights=ttmp
        input=self.question+self.data.format(names,heights)+self.instruction+self.rule
        name_heights=[]
        name_new=[]
        iteration_time=0
        iteration_time_1=0
        output=self.question+self.initialize.format(names,heights)
        while iteration_time<len(names):
            output+=self.iteration_2_1_enter.format(iteration_time,len(names))
            name_heights+=[[heights[iteration_time],names[iteration_time]]]
            iteration_time+=1
            output+=self.iteration_2_1_enter_inside_1.format(name_heights,iteration_time,iteration_time-1)
        name_heights.sort(reverse=True)
        output+=self.iteration_2_1__do_not_enter.format(iteration_time,len(names),name_heights)
        while iteration_time_1<len(names):
            output+=self.iteration_2_2_enter.format(iteration_time_1,len(names))
            name_height=name_heights.pop(0)
            name_new.append(name_height[1])
            iteration_time_1+=1
            output+=self.iteration_2_2_enter_inside_1.format(name_height,name_new,iteration_time_1,iteration_time_1-1)
        output+=self.iteration_2_2_do_not_enter.format(iteration_time_1,len(names),name_new)
        return {"input":input,
                "output":output,
                'answer':name_new}


        


