class Prompt:
    def __init__(self, dataset_name) -> None:
        if dataset_name == "coin_flip":
            self.rule = '''
def coin_flip(flips):
    # Initialize Coin State
    heads_up = True
    # Main Loop
    while flips:
        flip = flips.pop(0)
        if flip:
            heads_up = not heads_up
        else:
            pass
    return heads_up'''
            self.initialize = '''flips = {}
1. Initialize Coin State
heads_up = True
2. Main Loop'''

            self.one_iteration_2_1_flip = '''
2.1 one iteration
```
while flips:
```
flips = {}
enter
```
flip = flips.pop(0)
```
flips = {}
flip = flips.pop(0) = True
flips = {}
```
if flip:
```
flip = True
enter
```
heads_up = not heads_up
```
heads_up = {}
heads_up = not heads_up = {}
'''
            self.one_iteration_2_1_no_flip = '''
2.1 one iteration
```
while flips:
```
flips = {}
enter
```
flip = flips.pop(0)
```
flips = {}
flip = flips.pop(0) = False
flips = {}
```
if flip:
```
flip = False
do not enter
```
else:
    pass
```
heads_up = {}'''
            self.return_result = '''2.1 one iteration
```
while flips:
```
flips = []
not enter
3. Return Result
```
return heads_up
```
heads_up = {}

So the answer is {}.'''
        elif dataset_name == "coin_flip_natural":
            self.rule = '''# Initialize Coin State
the coin heads up initially
# Main Loop
when there are still people waiting to flip the coin, enter the loop:
    let the next person do the operation
    if the next person flips the coin, the coin state changes
    if the next person does not flip the coin, the coin state remains the same
return the final coin state
'''
            self.initialize = '''status of people waiting in line: {}
1. Initial State
The coin heads up initially
2. Main Loop
'''
            self.one_iteration_2_1_flip = '''2.1 one iteration
```
when there are still people waiting to flip the coin, enter the loop:
```
status of people waiting in line: {}
enter the loop
```
let the next person do the operation
```
status of people waiting in line: {}
the next person flips the coin
status of people waiting in line: {}
```
if the next person flips the coin, the coin state changes
```
the coin state changes from {} to {}
the coin heads {} now
'''
            self.one_iteration_2_1_no_flip = '''2.1 one iteration
```
when there are still people waiting to flip the coin, enter the loop:
```
status of people waiting in line: {}
enter the loop
```
let the next person do the operation
```
status of people waiting in line: {}
the next person does not flip the coin
status of people waiting in line: {}
```
if the next person does not flip the coin, the coin state remains the same
```
the coin state remains the same
the coin heads {} now
'''
            self.return_result = '''2.1 one iteration
```
when there are still people waiting to flip the coin, enter the loop:
```
status of people waiting in line: 
do not enter the loop
3. Return Result
```
return the final coin state
```
the coin heads {} now
So the answer is {}.
'''
        elif dataset_name == "last_letter_concat":
            self.rule = '''
def last_letter_concat(names):
    # Initialize Result
    result = ""
    # Main Loop
    while names:
        name = names.pop(0)
        result += name[-1]
    return result'''
            self.initialize = '''names = {}
1. Initialze Result
result = ""
2. Main Loop'''
            self.one_iteration_2_1 = '''
2.1 one iteration
```
while names:
```
names = {}
enter
```
name = names.pop(0)
```
names = {}
name = names.pop(0) = "{}"
names = {}
```
result += name[-1]
```
result = "{}"
name[-1] = "{}"
result += "{}"
result = "{}"'''

            self.return_result = '''
2.1 one iteration
```
while names:
```
names = []
do not enter
3. Return Result
```
resturn result
```
result = "{0}"

So the answer is "{0}".'''
        elif dataset_name == "reverse_list":
            self.rule = '''
def reverse_list(l):
    # Initialize Result
    result = []
    # Main Loop
    while l:
        result.append(l.pop())
    return result'''
            self.initialize = '''l = {}
1. Initialze result
result = []
2. Main Loop'''
            self.one_iteration_2_1 = '''
2.1 one iteration
```
while l:
```
l = {0}
enter
```
result.append(l.pop())
```
result = {1}
l.pop() = '{2}'
result = result.append('{2}') = {3}
l = {4}'''

            self.return_result = '''
2.1 one iteration
```
while l:
```
l = []
do not enter
3. Return Result
```
resturn result
```
result = {0}

So the answer is {0}.'''

        elif dataset_name == "object_counting":
            self.rule = '''
PROCEDURE object_counting(objects, target);
    # Initialize Count
    count <- 0;
    # Main Loop
    WHILE objects IS NOT EMPTY DO
        object <- objects[0];  # Get the first object in the remaining list
        objects <- objects[1 to -1];  # Remove the first object from the list
        IF object belong to target THEN
            count <- count + object.num;
        ENDIF
    ENDWHILE
    # Output Result
    OUTPUT count'''
            self.initialize = '''objects = {}
target = {}
1. Initialize Count
count = 0
2. Main Loop'''
            self.one_iteration_2_1_class = '''
2.1 one iteration
```
WHILE objects IS NOT EMPTY DO
```
objects = {5}
enter
```
object <- objects[0];  # Get the first object in the remaining list
```
object = objects[0] = {0}
```
objects <- objects[1 to -1];  # Remove the first object from the list
```
objects = objects[1 to -1] = {6}
```
IF <<object belong to {1}>> THEN
```
{0} belong to {1}
enter
```
count <- count + object.num;
```
count = {2}
object.num = {0}.num = {3}
count = count + object.num = {2} + {3} = {4}'''
            self.one_iteration_2_1_not_class = '''
2.1 one iteration
```
WHILE objects IS NOT EMPTY DO
```
objects = {3}
enter
```
object <- objects[0];  # Get the first object in the remaining list
```
object = objects[0] = {0}
```
objects <- objects[1 to -1];  # Remove the first object from the list
```
objects = objects[1 to -1] = {4}
```
IF <<object belong to {1}>> THEN
```
{0} do not belong to {1}
do not enter
count = {2}'''

            self.return_result = '''
3. Return Result
```
OUTPUT count
```
count = {0}

So the answer is {0}.'''

        elif dataset_name == "dyck_languages":
            self.rule = '''
def complete(s):
    ketbra_map = {")": "(", "}": "{", "]": "[", ">": "<"}
    # Initialize Stack
    stack = []
    # Stack Loop
    while s:
        braket = s[0]
        s = s[1:]
        if braket in ketbra_map:
            top = stack.pop() if stack else None
            if ketbra_map[braket] != top:
                return "invalid"
        else:
            stack.append(braket)
    # Initialize Complete
    braket_map = {'(': ')', '{': '}', '[': ']', '<': '>'}
    complete = []
    # Completion Loop
    while stack:
        complete.append(braket_map[stack.pop()])
    # Return Result
    return complete'''

            self.initialize_1 = '''s = {}'''
            self.initialize_2 = '''
ketbra_map = {'(': ')', '{': '}', '[': ']', '<': '>'}
1. Initialize Stack
stack = []
2. Stack Loop'''

            self.one_iteration_2_1_map = '''
2.1 one iteration
```
while s:
```
s = {5}
enter
```
braket = s[0]
s = s[1:]
```
s = {5}
braket = s[0] = '{0}'
s = s[1:] = {6}
```
if braket in ketbra_map:
```
'{0}' in [')', '}}', ']', '>']
enter
```
top = stack.pop() if stack else None
```
stack = {1}
enter
top = stack.pop() = '{2}'
stack = {3}
```
if ketbra_map[braket] != top:
```
ketbra_map[braket] = ketbra_map['{0}'] = '{4}'
top = '{2}'
ketbra_map[braket] == top
do not enter'''
            self.one_iteration_2_1_not_map = '''
2.1 one iteration
```
while s:
```
s = {3}
enter
```
braket = s[0]
s = s[1:]
```
s = {3}
braket = s[0] = '{0}'
s = s[1:] = {4}
```
if braket in ketbra_map:
```
'{0}' not in [')', '}}', ']', '>']
do not enter
```
else:
    stack.append(braket)
```
stack = {1}
braket = '{0}'
stack.append('{0}')
stack = {2}'''

            self.initialize_complete = '''
2.1 one iteration
```
while s:
```
s = []
do not enter
3. Initialize Complete
braket_map = {'(': ')', '{': '}', '[': ']', '<': '>'}
complete = []
4. Completion Loop'''

            self.one_iteration_4_1_stack = '''
4.1 one iteration
```
while stack:
```
stack = {0}
enter
```
complete += [braket_map[stack.pop()]]
```
stack.pop() = '{1}'
braket_map['{1}'] = '{2}'
complete = complete + ['{2}'] = {3} + ['{2}'] = {4}
stack = {5}'''

            self.one_iteration_4_1_not_stack = '''
4.1 one iteration
```
while stack:
```
stack = []
do not enter'''

            self.return_result = '''
5. Return Result
```
return complete
```
complete = {0}

So the answer is {0}.'''

        elif dataset_name == "hyperbaton":
            self.rule = '''
Correct order of the type of adjectives is:
opinion, size, physical quality, shape, age, colour, origin, material, type, purpose.

PROCEDURE adjective_judge(adjs);
    # Initialize
    current_type <- None;
    correct <- True;
    # Main Loop
    While adjs IS NOT EMPTY DO
        adj <- adjs[0]
        adjs <- adjs[1 to -1]
        IF adj.type later than current type THEN
            current_type <- adj.type;
        ELSE
            correct <- False
            break
        ENDIF
    ENDFOR
    # Output Result
    OUTPUT correct'''
            self.initialize = '''1. Initialize Type
current_type = None
correct = True
2. Main Loop'''
            self.one_iteration_2_1_later = '''
2.1 one iteration
```
While adjs IS NOT EMPTY DO
```
adjs = {3}
enter
```
adj <- adjs[0]
```
adj = adjs[0] = '{0}'
```
adjs <- adjs[1 to -1]
```
adjs = {4}
```
IF <<adj.type later than current type>> THEN
```
current_type is {1}
'{0}' is used to describe {2}
{2} should appear later than {1}
enter
```
current_type <- adj.type;
```
current_type = adj.type = {2}'''
            self.one_iteration_2_1_earlier = '''
2.1 one iteration
```
While adjs IS NOT EMPTY DO
```
adjs = {3}
enter
```
adj <- adjs[0]
```
adj = adjs[0] = '{0}'
```
adjs <- adjs[1 to -1]
```
adjs = {4}
```
IF <<adj.type later than current type>> THEN
```
current_type is {1}
'{0}' is used to describe {2}
{2} should appear ealier than {1}
do not enter
```
ELSE
    correct <- False
    break
```
correct = False
end the loop'''
            self.end_iter = '''
2.1 one iteration
```
While adjs IS NOT EMPTY DO
```
adjs = []
do not enter'''
            self.return_result = '''
3. Return Result
```
OUTPUT correct
```
correct = {}

So the answer is {}.'''

        elif dataset_name == "navigate":
            self.rule = '''
def navigate(moves):
    # Initialize Location
    loc = [0, 0]
    # Main Loop
    while moves:
        move = moves.pop(0)
        if move[0] == "left":
            loc[0] -= move[1]
        elif move[0] == "right":
            loc[0] += move[1]
        elif move[0] == "forward":
            loc[1] += move[1]
        elif move[0] == "backward":
            loc[1] -= move[1]
    return loc == [0, 0]'''
            self.initialize = '''moves = {}
1. Initialze result
loc = [0, 0]
2. Main Loop'''
            self.one_iteration_2_1_left = '''
2.1 one iteration
```
while moves:
```
moves = {6}
enter
```
move = moves.pop(0)
```
moves = {6}
move = moves.pop(0) = {0}
moves = {7}
```
if move[0] == "left":
    loc[0] -= move[1]
```
loc = {1}
move[1] = {2}
loc[0] = loc[0] - move[1] = {3} - {2} = {4}
loc = {5}'''

            self.one_iteration_2_1_right = '''
2.1 one iteration
```
while moves:
```
moves = {6}
enter
```
move = moves.pop(0)
```
moves = {6}
move = moves.pop(0) = {0}
moves = {7}
```
if move[0] == "right":
    loc[0] += move[1]
```
loc = {1}
move[1] = {2}
loc[0] = loc[0] + move[1] = {3} + {2} = {4}
loc = {5}'''

            self.one_iteration_2_1_forward = '''
2.1 one iteration
```
while moves:
```
moves = {6}
enter
```
move = moves.pop(0)
```
moves = {6}
move = moves.pop(0) = {0}
moves = {7}
```
if move[0] == "forward":
    loc[1] += move[1]
```
loc = {1}
move[1] = {2}
loc[1] = loc[1] + move[1] = {3} + {2} = {4}
loc = {5}'''

            self.one_iteration_2_1_backward = '''
2.1 one iteration
```
while moves:
```
moves = {6}
enter
```
move = moves.pop(0)
```
moves = {6}
move = moves.pop(0) = {0}
moves = {7}
```
if move[0] == "backward":
    loc[1] -= move[1]
```
loc = {1}
move[1] = {2}
loc[1] = loc[1] - move[1] = {3} - {2} = {4}
loc = {5}'''

            self.return_result = '''
2.1 one iteration
```
while moves:
```
moves = []
do not enter
3. Return Result
```
return loc == [0, 0]
```
loc = {}
loc == [0, 0] = {}

So the answer is {}.'''

        elif dataset_name == "word_sorting":
            self.rule = '''
def word_sorting(words):
    n = len(words)
    # Main Loop
    for i in range(n):
        for j in range(0, n-i-1):
            # Compare Words Letter By Letter
            same = True
            for k in range(min(len(words[j]), len(words[j+1]))):
                if words[j][k] > words[j+1][k]:
                    # Swap the words
                    words[j], words[j+1] = words[j+1], words[j]
                    same = False
                    break
                elif words[j][k] < words[j+1][k]:
                    same = False
                    break
            # Check If Prefix
            if same and len(words[j]) > len(words[j+1]):
                # Swap the words
                words[j], words[j+1] = words[j+1], words[j]
    return words'''
            self.initialize = '''
words = {}
len(words) = {}
1. Main Loop'''
            self.one_iteration_1_1_i = '''
1.1 one iteration (i)
```
for i in range(n):
```
i = {}'''
            self.one_iteration_1_1_1_j = '''
1.1.1 one iteration (j)
```
for j in range(0, n-i-1):
```
j = {}
words[j] = "{}"
words[j+1] = "{}"
1.1.1.1 Compare Words Letter By Letter
same = True'''
            self.one_iteration_1_1_1_1_1_k_big = '''
1.1.1.1.1 one iteration (k)
```
for k in range(min(len(words[j]), len(words[j+1]))):
```
len(words[j]) = {0}
len(words[j+1]) = {1}
min(len(words[j]), len(words[j+1])) = {2}
k = {3}
```
if words[j][k] > words[j+1][k]:
```
words[j][k] = "{4}"
words[j+1][k] = "{5}"
"{4}" > "{5}"
enter
```
# Swap the words
words[j], words[j+1] = words[j+1], words[j]
same = False
break
```
words = {6}
swap words[j] = "{7}" and words[j+1] = "{8}"
words = {9}
same = False
break'''

            self.one_iteration_1_1_1_1_1_k_small = '''
1.1.1.1.1 one iteration (k)
```
for k in range(min(len(words[j]), len(words[j+1]))):
```
len(words[j]) = {0}
len(words[j+1]) = {1}
min(len(words[j]), len(words[j+1])) = {2}
k = {3}
```
if words[j][k] > words[j+1][k]:
```
words[j][k] = "{4}"
words[j+1][k] = "{5}"
"{4}" < "{5}"
do not enter
```
elif words[j][k] < words[j+1][k]:
```
words[j][k] = "{4}"
words[j+1][k] = "{5}"
"{4}" < "{5}"
enter
```
same = False
break
```
same = False'''

            self.one_iteration_1_1_1_1_1_k_equal = '''
1.1.1.1.1 one iteration (k)
```
for k in range(min(len(words[j]), len(words[j+1]))):
```
len(words[j]) = {0}
len(words[j+1]) = {1}
min(len(words[j]), len(words[j+1])) = {2}
k = {3}

```
if words[j][k] > words[j+1][k]:
```
words[j][k] = "{4}"
words[j+1][k] = "{5}"
"{4}" = "{5}"
do not enter
```
elif words[j][k] < words[j+1][k]:
```
words[j][k] = "{4}"
words[j+1][k] = "{5}"
"{4}" = "{5}"
do not enter'''

            self.check_if_prefix_1_1_1_1_2_enter = '''
1.1.1.1.2 Check If Prefix
```
if same and len(words[j]) > len(words[j+1])::
```
same = {0}
len(words[j]) = {1}
len(words[j+1]) = {2}
len(words[j]) > len(words[j+1]) = {3}
same and len(words[j]) > len(words[j+1]) = {0} and {3} = True
enter
```
# Swap the words
words[j], words[j+1] = words[j+1], words[j]
```
words = {4}
swap words[j] = "{5}" and words[j+1] = "{6}"
words = {7}'''
            self.check_if_prefix_1_1_1_1_2_not_enter = '''
1.1.1.1.2 Check If Prefix
```
if same and len(words[j]) > len(words[j+1])::
```
same = {0}
len(words[j]) = {1}
len(words[j+1]) = {2}
len(words[j]) > len(words[j+1]) = {3}
same and len(words[j]) > len(words[j+1]) = {0} and {3} = False
do not enter
words = {4}'''
            self.return_result = '''
3. Return Result
```
return words
```
words = {}

So the answer is "{}".'''