# 5-shot
standard_prompt = '''Use numbers and basic arithmetic operations (+ - * /) to obtain 24.
Input: 4 4 6 8
Answer: (4 + 8) * (6 - 4) = 24
Input: 2 9 10 12
Answer: 2 * 12 * (10 - 9) = 24
Input: 4 9 10 13
Answer: (13 - 9) * (10 - 4) = 24
Input: 1 4 8 8
Answer: (8 / 4 + 1) * 8 = 24
Input: 5 5 5 9
Answer: 5 + 5 + 5 + 9 = 24
Input: {input}
'''

# 5-shot
cot_prompt = """I am working on problems where I combine four numbers using basic arithmetic operations (+, -, *, /) to obtain a single final result. At each step, I combine two numbers or intermediate results, ultimately arriving at one number at the end.

For previous examples, I have the sequence of calculation steps, and then I form the complete equation by combining them in the correct order, using appropriate parentheses:

Example 1:
Steps:
1 + 2 = 3 
5 - 9 = -4
-4 * 3 = -12
Answer: (1 + 2) * (5 - 9) = -12

Example 2:
Steps:
5 - 2 = 3
3 * 4 = 12
12 - 7 = 5
Answer: ((5 - 2) * 4) - 7 = 5

Example 3:
Steps:
10 + 13 = 23
4 * 9 = 36
36 - 23 = 13
Answer: (4 * 9) - (10 + 13) = 13

Now, given a new set of steps, please follow the same logic and reasoning. Build the complete equation by correctly nesting all operations with parentheses, and present it in the same format:
Answer only with "Answer: " followed by the equation and nothing else!
Steps:
{steps}"""

# 1-shot
propose_prompt = """You are given a set of numbers. Your task is to choose exactly two of these numbers, and then use one of the basic arithmetic operations (addition +, subtraction -, multiplication *, or division /) to combine them into a new number. Then, replace the two numbers you chose with the result of your calculation, leaving you with one fewer number in the list.

Instructions:
- You must select two different numbers from the list.
- Apply one of the four basic operations (+, -, *, or /).
- Show the result as a new number, and update the list to show the numbers that remain after this step.
- List all possible valid choices for this step as separate lines.

Example Input:
2 8 8 14

Example Output:
2 + 8 = 10 (left: 8 10 14)
8 / 2 = 4 (left: 4 8 14)
14 + 2 = 16 (left: 8 8 16)
2 * 8 = 16 (left: 8 14 16)
8 - 2 = 6 (left: 6 8 14)
14 - 8 = 6 (left: 2 6 8)
14 / 2 = 7 (left: 7 8 8)
14 - 2 = 12 (left: 8 8 12)

Task:
Given the input below, list all possible valid next steps according to the instructions above.
Do not use numbered lists! Stick exactly to the formatting as shown above!

Input:
{input}"""

value_prompt = '''Evaluate if given numbers can reach 24 (sure/likely/impossible).
Here is how you should approach it:

Input: 10 14
Output:
10 + 14 = 24
sure

Input: 11 12
Output:
11 + 12 = 23
12 - 11 = 1
11 * 12 = 132
11 / 12 = 0.91
impossible

Input: 4 4 10
Output:
4 + 4 + 10 = 8 + 10 = 18
4 * 10 - 4 = 40 - 4 = 36
(10 - 4) * 4 = 6 * 4 = 24
sure

Input: 4 9 11
Output:
9 + 11 + 4 = 20 + 4 = 24
sure

Input: 5 7 8
Output:
5 + 7 + 8 = 12 + 8 = 20
(8 - 5) * 7 = 3 * 7 = 21
I cannot obtain 24 now, but numbers are within a reasonable range
likely

Input: 5 6 6
Output:
5 + 6 + 6 = 17
(6 - 5) * 6 = 1 * 6 = 6
I cannot obtain 24 now, but numbers are within a reasonable range
likely

Input: 10 10 11
Output:
10 + 10 + 11 = 31
(11 - 10) * 10 = 10
10 10 10 are all too big
impossible

Input: 1 3 3
Output:
1 * 3 * 3 = 9
(1 + 3) * 3 = 12
1 3 3 are all too small
impossible

Input: {input}
Output:'''

value_last_step_prompt = '''Use numbers and basic arithmetic operations (+ - * /) to obtain 24. Given an input and an answer, give a judgement (sure/impossible) if the answer is correct, i.e. it uses each input exactly once and no other numbers, and reach 24.
Input: 4 4 6 8
Answer: (4 + 8) * (6 - 4) = 24
Judge: 
sure
Input: 2 9 10 12
Answer: 2 * 12 * (10 - 9) = 24
Judge: 
sure
Input: 4 9 10 13
Answer: (13 - 9) * (10 - 4) = 24
Judge: 
sure
Input: 4 4 6 8
Answer: (4 + 8) * (6 - 4) + 1 = 25
Judge: 
impossible
Input: 2 9 10 12
Answer: 2 * (12 - 10) = 24
Judge: 
impossible
Input: 4 9 10 13
Answer: (13 - 4) * (10 - 9) = 24
Judge: 
impossible
Input: {input}
Answer: {answer}
Judge:'''



verify_math_prompt = '''[
    {"role":"user", "content":"""Here are some calculations:
"{input}"
Is the **last** equation I carried out correct? Ignore everything in the parentheses and focus only on the last equation."""}
]
'''

verify_leftovers_prompt = '''[
    {"role":"user", "content":"""Check whether the leftover numbers are the correct numbers.
Always look at the last two steps and ignore the rest. If there is only one step given, the numbers in Input must be used as the first step.
The leftover numbers of the final step, e.g. "(left: 4 6)" must be exactly the input numbers of the preceeding step, e.g. "(left: 2 6 8)", where two numbers are replaced by the result of the given equation, e.g. "8 / 2 = 4".
The order of the numbers does not matter.
As a quick check, the amount of numbers in the input is always exactly one more than in the remaining numbers. E.g. if four input numbers are given, three must remain. If this rule is violated, the approach can never be correct.
Here is how it works:

Input: 
'4 4 6 8'
Steps: 
'4 + 8 = 12 (left: 4 6 12)'
Reasoning:
There is only one step, so we have to compare it to the given input '4 4 6 8'.
Quick check: We have four input numbers, therefore we must have exactly three numbers left. This seems to be the case, so we can continue.
The final step uses 4 and 8 and gives 12. It claims that 4 6 12 are left. Let's see.
Taking 4 and 8 out of the input 4 4 6 8 leaves 4 6. The calculation gave 12, resulting in 4 6 12. The numbers in the parentheses are 4 6 12, which are the same, so the numbers are correct.
Answer: correct

Input:
'4 5 6 8'
Steps:
'6 - 5 = 1 (left: 1 4 8)
4 - 1 = 3 (left: 3)'
Reasoning:
Here we need to compare the last two steps, taking what's left in the penultimate step as input to the final step.
Thus, we have '1 4 8' as input.
Quick check: We have three input numbers 1 4 8, therefore we must have exactly two numbers left. However, only 3 was given, which can never be true, so the numbers are incorrect.
Answer: incorrect

Input:
'2 8 8 14'
Steps:
'14 + 8 = 22 (left: 2 8 22)
22 / 2 = 11 (left: 8 11)
8 + 11 = 19 (left: 19)'
Reasoning:
Here we need to compare the last two steps, taking what's left in the penultimate step as input to the final step.
Quick check: We have two input numbers 8 11, so we must have exactly one number left. 19 is given, so the quick check is okay. Let's check the correctness now.
Taking 8 and 11 out of the input 8 11 leaves no numbers. The calculation gave 19, resulting in a set of 19. The leftover numbers in the last step are 19, so the numbers are correct.
Answer: correct

Now, please apply the same reasoning and rules to this new input and give your best judgment on the correctness:
Input: 
'{input}'
Steps: 
'{steps}'
Make sure to end with 'Answer: correct/incorrect'."""},
]
'''

verify_numbers_selection_prompt = '''[
    {"role":"user", "content":"""Check whether the two numbers in the equation are included in the input numbers. 
Ignore everything after "=".
Input: '4 4 6 8'
Equation: '4 / 4 = 2 (left: 2 6 8)'"""},
    {"role":"assistant", "content": """The numbers in the equation are 4 and 4. They both occur in the numbers in the input 4 4 6 8, so they are correct.
Answer: correct"""},
    {"role":"user", "content": """Input: '3 * 2 = 6 (left: 3 6 7)'
Equation: '1 + 5 = 6 (left: 3 6 7)'"""},
    {"role":"assistant", "content": """The numbers in the equation are 1 and 5. The given input is 3 6 7. 5 does not occur in the input 3 6 7, so they are incorrect.
Answer: incorrect"""},
    {"role":"user", "content": """Input: '2 * 8 = 16 (left: 8 14 16)
14 + 16 = 30 (left: 8 30)'
Equation: '30 - 8 = 22 (left: 22)'"""},
    {"role":"assistant", "content": """The numbers in the equation are 30 and 8. The given input is 8 30. Both numbers occur in the input, so they are incorrect.
Answer: correct"""},
    {"role":"user", "content": """Input {input}
Equation {steps}"""},
]
'''