-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfull calculator (3.0).py
142 lines (103 loc) · 4.51 KB
/
full calculator (3.0).py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
# starting variables
import math
instruction_list_unprocessed = []
instruction_list = []
# user interface
print("this is a calculator that can perform many common mathematical functions")
print("your input must be a single string of text with no spaces")
print("possible operations: +, -, *, /, //, %, **, sqrt")
# inputs and initial processing
equation = input("please enter equation...")
total_length = len(equation)
# moving each character of the equation to a separate variable in a list (instruction_list_unprocessed)
for i in range(total_length):
instruction_list_unprocessed.append(equation[i])
instruction_list_unprocessed.append("x")
# consolidating multi digit numbers
for i in range(total_length):
if str(instruction_list_unprocessed[i]).isnumeric():
if str(instruction_list_unprocessed[i + 1]).isnumeric():
instruction_list_unprocessed[i + 1] = instruction_list_unprocessed[i] + instruction_list_unprocessed[i + 1]
instruction_list_unprocessed[i] = "empty"
# consolidating muliti character operators
for i in range(total_length):
if str(instruction_list_unprocessed[i]).isnumeric():
b = 0
else:
if instruction_list_unprocessed[i] == instruction_list_unprocessed[i + 1]:
instruction_list_unprocessed[i + 1] = instruction_list_unprocessed[i] + instruction_list_unprocessed[i + 1]
instruction_list_unprocessed[i] = "empty"
# consolidating sqrt command
for i in range(total_length):
if str(instruction_list_unprocessed[i]).isalpha():
if str(instruction_list_unprocessed[i]) == "s":
instruction_list.append("sqrt")
else: instruction_list.append(instruction_list_unprocessed[i])
# inputs are processed here before calculation
length = len(instruction_list)
operation_count = 0
# sqrt module
sqrt_count = instruction_list.count("sqrt")
for i in range(sqrt_count):
x = instruction_list.index("sqrt")
instruction_list[x] = math.sqrt(int(instruction_list[x + 1]))
instruction_list.pop(x + 1)
operation_count = operation_count + 2
# indices module
power_count = instruction_list.count("**")
for i in range(power_count):
x = instruction_list.index("**")
instruction_list[x] = int(instruction_list[x - 1]) ** int(instruction_list[x + 1])
instruction_list.pop(x + 1)
instruction_list.pop(x - 1)
operation_count = operation_count + 2
# multiplication module
multiplication_count = instruction_list.count("*")
for i in range(multiplication_count):
x = instruction_list.index("*")
instruction_list[x] = int(instruction_list[x - 1]) * int(instruction_list[x + 1])
instruction_list.pop(x + 1)
instruction_list.pop(x - 1)
operation_count = operation_count + 2
# remainder division module
remainder_div_count = instruction_list.count("%")
for i in range(remainder_div_count):
x = instruction_list.index("%")
instruction_list[x] = int(instruction_list[x - 1]) % int(instruction_list[x + 1])
instruction_list.pop(x + 1)
instruction_list.pop(x - 1)
operation_count = operation_count + 2
# integer division module
int_div_count = instruction_list.count("//")
for i in range(int_div_count):
x = instruction_list.index("//")
instruction_list[x] = int(instruction_list[x - 1]) // int(instruction_list[x + 1])
instruction_list.pop(x + 1)
instruction_list.pop(x - 1)
operation_count = operation_count + 2
# division module
division_count = instruction_list.count("/")
for i in range(division_count):
x = instruction_list.index("/")
instruction_list[x] = int(instruction_list[x - 1]) / int(instruction_list[x + 1])
instruction_list.pop(x + 1)
instruction_list.pop(x - 1)
operation_count = operation_count + 2
# addition module
addition_count = instruction_list.count("+")
for i in range(addition_count):
x = instruction_list.index("+")
instruction_list[x] = int(instruction_list[x - 1]) + int(instruction_list[x + 1])
instruction_list.pop(x + 1)
instruction_list.pop(x - 1)
operation_count = operation_count + 2
# subtraction module
subtraction_count = instruction_list.count("-")
for i in range(subtraction_count):
x = instruction_list.index("-")
instruction_list[x] = int(instruction_list[x - 1]) - int(instruction_list[x + 1])
instruction_list.pop(x + 1)
instruction_list.pop(x - 1)
operation_count = operation_count + 2
answer = instruction_list[i]
print("your answer is:", answer)