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
    for flip in flips:
        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
```
for flip in flips:
```
flip = True
```
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
```
for flip in flips:
```
flip = False
```
if flip:
```
flip = False
do not enter
```
else:
    pass
```
heads_up = {}'''
            self.return_result = '''
3. Return Result
```
return heads_up
```
heads_up = {}

So the answer is {}.'''
        elif dataset_name == "max_consecutive_ones":
            self.rule = '''
def max_consecutive_ones(nums):
    # Initialize the final answer
    ans = cnt = 0
    # Main Loop
    while nums != []:
        num = nums.pop(0)
        if num == 1:
            cnt += 1
        else:
            cnt = 0
        ans = max(ans, cnt)
    return ans'''
            self.initialize = '''
nums = {}
1. Initialize final answer
ans = 0
cnt = 0
2. Main Loop'''
            self.one_iteration_2_1_count = '''
2.1 one iteration
```
while nums != []:
```
nums = {} != []
enter
```
num = nums.pop(0)
```
num = {}
nums = {}
```
if num == 1:
```
num = 1
enter
```
cnt += 1
```
cnt = {}
```
ans = max(ans, cnt)
```
ans = {}
ans = max(ans, cnt) = {}'''
            self.one_iteration_2_1_to0 = '''
2.1 one iteration
```
while nums != []:
```
nums = {} != []
enter
```
num = nums.pop(0)
```
num = {}
```
if num == 1:
```
num = 0
do not enter
```
else:
    cnt = 0
```
cnt = {}
```
ans = max(ans, cnt)
```
ans = {}
ans = max(ans, cnt) = {}'''
            self.one_iteration_2_1_break = '''
```
while nums != []:
```
nums = []
do not enter'''
            self.return_result = '''
3. Return Result
```
return ans
```
ans = {}
So the answer is {}.'''
        elif dataset_name == "hamming_distance":
            self.rule = '''
def hamming_distance(x, y):
    # Initialize
    ans = 0
    # Main Loop
    while x != 0 or y != 0:
        if x % 2 != y % 2:
            ans += 1
        x //= 2
        y //= 2
    return ans'''
            self.initialize = '''1. Initialize
ans = 0
x = {}
y = {}
2. Main Loop
'''
            self.one_iteration_2_1_different = '''```
while x != 0 or y != 0:
```
x = {}
y = {}
(x != 0 or y != 0) = True
enter the loop
2.1 one iteration
```
if x % 2 != y % 2:
    ans += 1
```
x % 2 = {}
y % 2 = {}
enter if
ans = {} + 1 = {}
```
x //= 2
y //= 2
```
x = {}
y = {}
now,
x = {}
y = {}
'''
            self.one_iteration_2_1_same = '''```
while x != 0 or y != 0:
```
x = {}
y = {}
(x != 0 or y != 0) = True
enter the loop
2.1 one iteration
```
if x % 2 != y % 2:
    ans += 1
```
x % 2 = {}
y % 2 = {}
do not enter
```
x //= 2
y //= 2
```
x = {}
y = {}
now,
x = {}
y = {}
'''
            self.one_iteration_2_1_break = '''```
while x != 0 or y != 0:
```
x = 0b0
y = 0b0
(x != 0 or y != 0) = False
do not enter
'''
            self.return_result = '''3. Return Result
```
return ans
```
ans = {}
So the answer is {}'''
        elif dataset_name == "license_key_formatting":
            self.rule = '''
def hamming_distance(s, k):
    # Initialize Answer Variable and Loop Varible
    ans = ''
    cnt = 0
    # Main Loop
    while s != '':
        if s[-1] != '-':
            if cnt % k == 0 and ans != '':
                ans = '-' + ans
            ans = s[-1] + ans
            cnt += 1
        s = s[-1:]
    return ans.upper()'''
            self.initialize = '''
s = '{}'
k = {}
1. Initialize Answer Varible and Count Varible
ans = ''
cnt = 0
2. Main Loop'''
            self.one_iteration_2_1_in = '''
2.1 one iteration
```
while s != '':
```
s = {} != ''
enter
```
if s[-1] != '-':
```
s[-1] = '{}' != '-'
enter'''
            self.one_iteration_2_1_out = '''
2.1 one iteration
```
while s != '':
```
s = {} != ''
enter
```
if s[-1] != '-':
```
s[-1] = '-'
do not enter
```
s = s[-1:]
```
s = '{}' '''
            self.one_iteration_2_2_in = '''
```
if cnt % k == 0 and ans != '':
```
cnt = {}
k = {}
cnt % k == 0
ans = {} != ''
enter
```
ans = '-' + ans
```
ans = '{}'
```
ans = s[-1] + ans
cnt += 1
```
ans = '{}'
cnt = {}
```
s = s[-1:]
```
s = '{}' '''
            self.one_iteration_2_2_out = '''
```
if cnt % k == 0 and ans != '':
```
cnt = {}
k = {}
cnt % k = {}
ans = {}
do not enter
```
ans = s[-1] + ans
cnt += 1
```
ans = '{}'
cnt = {}
```
s = s[-1:]
```
s = '{}' '''
            self.one_iteration_2_break = '''
2.1 one iteration
```
while s != '':
```
s = ''
do not enter'''
            self.return_result = '''
3. Return Result
```
return ans.upper()
```
ans = '{}'
ans.upper = '{}'
So the answer is '{}'.'''
        elif dataset_name == "keyboard_row":
            self.rule = '''
def keyboard_row(words):
    # Initialize Answer List
    ans = []
    k1 = 'qwertyuiopQWERTYUIOP'
    k2 = 'asdfghjklASDFGHJKL'
    k3 = 'zxcvbnmZXCVBNM'
    # Main Loop
    while words != []:
        word = words.pop(0)
        lenWord = len(word)
        wordBackup = word
        # judge if the word is in one row of the keyboard
        cnt1 = cnt2 = cnt3 = 0 # count how many letters in each row
        while word != '':
            letter = word[0]
            if letter in k1:
                cnt1 += 1
            if letter in k2:
                cnt2 += 1
            if letter in k3:
                cnt3 += 1
            word = word[1:]
        if cnt1 == lenWord or cnt2 == lenWord or cnt3 == lenWord:
            ans.append(wordBackup)
    return ans'''
            self.initialize = '''
words = {}
1. Initialize Answer List
ans = []
k1 = 'qwertyuiopQWERTYUIOP'
k2 = 'asdfghjklASDFGHJKL'
k3 = 'zxcvbnmZXCVBNM'
2. Main Loop'''
            self.one_iteration_2_1_head = '''
2.1 one iteration
```
while words != []:
```
words = {} != []
enter
```
word = words.pop(0)
lenWord = len(word)
wordBackup = word
# judge if the word is in one row of the keyboard
cnt1 = cnt2 = cnt3 = 0 # count how many letters in each row
```
word = '{}'
lenWord = {}
wordBackup = '{}'
cnt1 = cnt2 = cnt3 = 0'''
            self.one_iteration_2_2_if1_true = '''
2.2 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0] in k1:
```
word[0] = '{}'
(word[0] in k1) == True
enter
```
cnt1 += 1
```
cnt1 = {}'''
            self.one_iteration_2_2_if1_false = '''
2.2 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0] in k1:
```
word[0] = '{}'
(word[0] in k1) == False
do not enter'''
            self.one_iteration_2_2_if2_true = '''
2.2 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0] in k2:
```
word[0] = '{}'
(word[0] in k2) == True
enter
```
cnt2 += 1
```
cnt2 = {}'''
            self.one_iteration_2_2_if2_false = '''
2.2 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0] in k2:
```
word[0] = '{}'
(word[0] in k2) == False
do not enter'''
            self.one_iteration_2_2_if3_true = '''
2.2 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0] in k3:
```
word[0] = '{}'
(word[0] in k3) == True
enter
```
cnt3 += 1
```
cnt3 = {}
```
word = word[1:]
```
word = '{}' '''
            self.one_iteration_2_2_if3_false = '''
2.2 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0] in k3:
```
word[0] = '{}'
(word[0] in k3) == False
do not enter
```
word = word[1:]
```
word = '{}' '''
            self.one_iteration_2_1_if_true = '''
```
if cnt1 == lenWord or cnt2 == lenWord or cnt3 == lenWord:
```
cnt1 = {}
cnt2 = {}
cnt3 = {}
lenWord = {} = {}
enter
```
ans.append(wordBackup)
```
ans = {}'''
            self.one_iteration_2_1_if_false = '''
```
if cnt1 == lenWord or cnt2 == lenWord or cnt3 == lenWord:
```
cnt1 = {}
cnt2 = {}
cnt3 = {}
lenWord = {}
do not enter'''
            self.return_result = '''
2.1 one iteration
```
while words != []:
```
words = []
do not enter
3. Return Result
```
return ans
```
ans = {}
So the answer is {}.'''
        elif dataset_name == "detect_capital":
            self.rule = '''
def detect_capital(word):
    # Initialize Count Variable and Loop Varible
    cnt = 0
    firstLetter = word[0]
    lenWord = len(word)
    # Main Loop
    while word != '':
        # Add to the counter if the letter is capital
        if word[0].isupper():
            cnt += 1
        word = word[1:]
    if cnt == 0 or cnt == len(word) or (cnt == 1 and firstLetter.isupper()):
        return True
    # else return False
    return False'''
            self.initialize = '''
word = '{}'
1. Initialize Answer Varible and Loop Varible
cnt = 0
firstLetter = word[0] = {}
lenWord = len(word) = {}
2. Main Loop'''
            self.one_iteration_2_1_in = '''
2.1 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0].isupper():
```
word[0] = '{}'
word[0].isupper() = True
enter
```
cnt += 1
```
cnt = '{}'
```
word = word[1:]
```
word = '{}' '''
            self.one_iteration_2_1_out = '''
2.1 one iteration
```
while word != '':
```
word = {} != ''
enter
```
if word[0].isupper():
```
word[0] = '{}'
word[0].isupper() = False
do not enter
```
word = word[1:]
```
word = '{}' '''
            self.one_iteration_2_1_break = '''
2.1 one iteration
```
while word != '':
```
word = ''
do not enter'''
            self.return_true = '''
3. Return Result
```
if cnt == 0 or cnt == lenWord or (cnt == 1 and firstLetter.isupper()):
```
cnt = {}
lenWord = {}
firstLetter = '{}'
firstLetter.isupper() = {}
enter
```
return True
```
So the answer is True.'''
            self.return_false = '''
3. Return Result
```
if cnt == 0 or cnt == lenWord or (cnt == 1 and word[0].isupper()):
```
cnt = {}
lenWord = {}
firstLetter = '{}'
firstLetter.isupper() = {}
do not enter
```
return False
```
So the answer is False.'''
        elif dataset_name == "design_hashset":
            self.rule = '''
def design_hashset(oper, keys):
    # Initialize Answer Variable and Loop Varible
    ans = []
    hashset = set()
    # Main Loop
    while oper != []:
        if oper[0] == 'add':
            hashset.add(keys[0])
            ans.append(None)
        if oper[0] == 'remove':
            hashset.discard(keys[0])
            ans.append(None)
        if oper[0] == 'contains':
            ans.append(keys[0] in hashset)
        oper.pop(0)
        keys.pop(0)
    return ans'''
            self.initialize = '''
oper = {}
keys = {}
1. Initialize Answer Varible and Loop Varible
ans = []
hashset = {{}}
2. Main Loop'''
            self.one_iteration_2_1_if1_true = '''
2.1 one iteration
```
while oper != []:
```
oper = {} != []
enter
```
if oper[0] == 'add':
```
oper[0] = 'add'
enter
```
hashset.add(keys[0])
ans.append(None)
```
hashset = {}
ans = {}
```
if oper[0] == 'remove':
```
oper[0] = 'add' != 'remove'
do not enter
```
if oper[0] == 'contains':
```
oper[0] = 'add' != 'contains'
do not enter
```
oper.pop(0)
keys.pop(0)
```
oper = {}
keys = {}'''
            self.one_iteration_2_1_if2_true = '''
2.1 one iteration
```
while oper != []:
```
oper = {} != []
enter
```
if oper[0] == 'add':
```
oper[0] = 'remove' != 'add'
do not enter
```
if oper[0] == 'remove':
```
oper[0] = 'remove'
enter
```
hashset.discord(keys[0])
ans.append(None)
```
hashset = {}
ans = {}
```
if oper[0] == 'contains':
```
oper[0] = 'remove' != 'contains'
do not enter
```
oper.pop(0)
keys.pop(0)
```
oper = {}
keys = {}'''
            self.one_iteration_2_1_if3_true = '''
2.1 one iteration
```
while oper != []:
```
oper = {} != []
enter
```
if oper[0] == 'add':
```
oper[0] = 'contains' != 'add'
do not enter
```
if oper[0] == 'remove':
```
oper[0] = 'contains' != 'remove'
do not enter
```
if oper[0] == 'contains':
```
oper[0] = 'contains'
enter
```
ans.append(keys[0] in hashset)
```
keys[0] = {}
hashset = {}
(keys[i] in hashset) = {}
ans = {}
```
oper.pop(0)
keys.pop(0)
```
oper = {}
keys = {}'''
            self.one_iteration_2_1_break = '''
2.1 one iteration
```
while oper != []:
```
oper = []
do not enter'''
            self.return_result = '''
3. Return Result
```
return ans
```
ans = {}
So the answer is {}.'''
        elif dataset_name == "jewels_and_stones":
            self.rule = '''
def jewels_and_stones(a, b):
    ans = [ch in a for ch in b].count(True)
    return ans'''
            self.initialize = '''
a = {}
b = {}
'''
            self.return_result = '''
2. Return Result
```
ans = [ch in a for ch in b].count(True)
```
[ch for ch in b] = {}
[ch in a for ch in b] = {}
ans = [ch in a for ch in b].count(True) = {}
So the answer is {}.'''
        elif dataset_name == "rotate_string":
            self.rule = '''
def rotate_string(s, goal):
    ans = False
    sBackup = s[-1] + s[:-1]
    while s != sBackup:
        if s[1:] + s[0] == goal:
            ans = True
        s = s[1:] + s[0]
    return ans'''
            self.initialize = '''
s = {}
goal = {}
1. Initialize Answer Varible and Loop Varible
ans = False
sBackup = s[-1] + s[:-1]
2. Main Loop'''
            self.one_iteration_2_1_if_true = '''
2.1 one iteration
```
while s != sBackup:
```
s = {}
sBackup = {}
s != sBackup
enter
```
if s[1:] + s[0] == goal:
```
s[1:] + s[0] = {} = goal
enter
```
ans = True
```
ans = {}
```
s = s[1:] + s[0]
```
s = {}'''
            self.one_iteration_2_1_if_false = '''
2.1 one iteration
```
while s != sBackup:
```
s = {}
sBackup = {}
s != sBackup
enter
```
if s[1:] + s[0] == goal:
```
s[1:] + s[0] = {}
goal = {}
s[1:] + s[0] != goal
do not enter
```
s = s[1:] + s[0]
```
s = {}'''
            self.one_iteration_2_1_break = '''
2.1 one iteration
```
while s != sBackup:
```
s = {} = sBackup
do not enter'''
            self.return_result = '''
2. Return Result
```
return ans
```
ans = {}
So the answer is {}.'''
