import random


class Dataset_Generator:
    def __init__(self) -> None:
        self.id = 2460  
        self.name = 'Apply operations to an array'   
        self.description = '''Conduct specific operations to an array'''  
        self.url="https://leetcode.com/problems/apply-operations-to-an-array/description/"
        self.question='''Q:You are given a 0-indexed array nums of size n consisting of non-negative integers.You need to apply n - 1 operations to this array where, in the ith operation (0-indexed), you will apply the following on the ith element of nums:
        If nums[i] == nums[i + 1], then multiply nums[i] by 2 and set nums[i + 1] to 0. Otherwise, you skip this operation.
        After performing all the operations, shift all the 0's to the end of the array.\n'''
        self.data="The given array is {}\n"
        self.instruction= "Follow the given rule to solve the question.\nrule: "
        self.rule='''
def applyOperations(self, a: List[int]) -> List[int]:
    iteration_time=0
    n=len(a)
    ans=[]
    while iteration_time< n-1:
        pre_num=a.pop(iteration_time)
        next_num=a.pop(iteration_time)
        if pre_num==next_num:
            pre_num*=2
            next_num=0
        a.insert(iteration_time,pre_num)
        a.insert(iteration_time+1,next_num) #finish step one
        iteration_time+=1
    while a:
        now_num=a.pop(-1)
        if now_num!=0:
            ans.insert(0,now_num)
        else:
            ans+=[now_num]
    return ans
'''

        self.initialize='''
1.Initialize iteration_time,n,ans,a
```
iteration_time=0
n=len(a)
ans=[]
a={0}
```
n={1}
2.Main loops'''
        self.iteration_2_1_enter='''
2.1 One iteration
```
while iteration_time< n-1:
```
iteration_time={0} 
n-1={1}
enter
'''
        self.iteration_2_1__do_not_enter='''
2.1 One iteration
```
while iteration_time< n-1:
```
iteration_time={0}
n-1={1} 
do not enter
'''
        self.iteration_2_1_enter_inside_1='''
```
pre_num=a.pop(iteration_time)
```
pre_num={0}
```
next_num=a.pop(iteration_time)
```
next_num={1}
'''
        self.IF_statement_1_enter='''
IF_statement_1
```
if pre_num==next_num:
```
pre_num={0}
next_num={1}
enter
'''
        self.IF_statement_1_enter_inside_1='''
```
pre_num*=2
```
pre_num={2}*2={0}
```
next_num=0
```
next_num={1}
'''

        self.IF_statement_1_do_not_enter='''
IF_statement_1
```
if pre_num==next_num:
```
pre_num={0}
next_num={1}
do not enter
'''
        self.main_loop_2_1='''
```
a.insert(iteration_time,pre_num)
```
iteration_time={0}
pre_num={1}
a={2}
'''
        self.main_loop_2_2='''
```
a.insert(iteration_time+1,next_num)
```
iteration_time={0}
next_num={1}
a={2}
```
iteration_time+=1
```
iteration_time={4}+1={3}
'''
        self.iteration_2_2_enter='''
2.2 One iteration
```
while a:
```
a={}
true
enter
'''
        self.iteration_2_2_enter_inside_1='''
```
now_num=a.pop(-1)
```
now_num={0}
```
'''
        self.IF_statement_2_enter='''
IF_statement_2
```
if now_num!=0:
```
now_num={0}
enter
```
ans.insert(0,now_num)
```
ans={1}
'''
        self.IF_statement_2_do_not_enter='''
IF_statement_2
```
if now_num!=0:
```
now_num={0}
do not enter
```
ans+=[now_num]
```
ans={1}
'''
        self.iteration_2_2_do_not_enter='''
2.2 One iteration
```
while a:
```
a=False
do not enter

So the answer is {0}
'''
    def gen_data_from_len(self,length:int)->list:
        '''
        return datapoint of given length
        '''
        n=length
        a=[]
        for i in range(n):
            a.append(random.randint(1,100))
        return a
    def rfft_IO(self, a: list) -> list:
        '''
        data: a datapoint from gen_data_from_len
        return rfft input-output of given data
        '''
        input=self.question+self.data.format(a)+self.instruction+self.rule
        iteration_time=0
        n=len(a)
        ans=[]
        output=self.question+self.initialize.format(a,n)
        while iteration_time< n-1:
            output+=self.iteration_2_1_enter.format(iteration_time,n-1)
            pre_num=a.pop(iteration_time)
            next_num=a.pop(iteration_time)
            output+=self.iteration_2_1_enter_inside_1.format(pre_num,next_num) 
            if pre_num==next_num:
                output+=self.IF_statement_1_enter.format(pre_num,next_num)
                pre_num*=2
                next_num=0
                output+=self.IF_statement_1_enter_inside_1.format(pre_num,next_num,pre_num/2)
            output+=self.IF_statement_1_do_not_enter.format(pre_num,next_num)
            a.insert(iteration_time,pre_num)
            output+=self.main_loop_2_1.format(iteration_time,pre_num,a)
            a.insert(iteration_time+1,next_num) 
            iteration_time+=1
            output+=self.main_loop_2_2.format(iteration_time,next_num,a,iteration_time,iteration_time-1)
        output+=self.iteration_2_1__do_not_enter.format(iteration_time,n-1)
        while a:
            output+=self.iteration_2_2_enter.format(a)
            now_num=a.pop(-1)
            output+=self.iteration_2_2_enter_inside_1.format(now_num)
            if now_num!=0:
                ans.insert(0,now_num)
                output+=self.IF_statement_2_enter.format(now_num,ans)
            else:
                ans+=[now_num]
                output+=self.IF_statement_2_do_not_enter.format(now_num,ans)
        output+=self.iteration_2_2_do_not_enter.format(ans)
        return {
            'input':input,
            'output':output,
            "answer":ans}



