-
-
Notifications
You must be signed in to change notification settings - Fork 298
/
Copy path650.py
42 lines (35 loc) · 1.13 KB
/
650.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
__________________________________________________________________________________________________
sample 28 ms submission
import math
class Solution:
def minSteps(self, n: int) -> int:
if n == 1:
return 0
if n == 2:
return 2
def gcd(num):
greatest = 1
for i in range(2, num // 2):
if num % i == 0:
greatest = i
return greatest
def rec(num):
if gcd(num) == 1:
return num
g = gcd(num)
got = rec(g)
return got + num // g
return rec(n)
__________________________________________________________________________________________________
sample 12972 kb submission
class Solution:
def minSteps(self, n: int) -> int:
ans = 0
f = 2
while n > 1:
while n % f == 0:
ans += f
n /= f
f += 1
return ans
__________________________________________________________________________________________________