-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProblem45.py
94 lines (61 loc) · 2.41 KB
/
Problem45.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
# Code by @AmirMotefaker
# projecteuler.net
# https://projecteuler.net/problem=45
# Triangular, pentagonal, and hexagonal
# Problem 45
# Triangle, pentagonal, and hexagonal numbers are generated by the following formulae:
# Triangle Tn=n(n+1)/2 1, 3, 6, 10, 15, ...
# Pentagonal Pn=n(3n−1)/2 1, 5, 12, 22, 35, ...
# Hexagonal Hn=n(2n−1) 1, 6, 15, 28, 45, ...
# It can be verified that T285 = P165 = H143 = 40755.
# Find the next triangle number that is also pentagonal and hexagonal.
# Solution 1
import time
start_time = time.time() #Time at the start of program execution
def is_pentagonal(p): # is_pentagonal check if the given number is pentagonal
if (1+(24*p+1)**0.5) % 6 == 0:
return True
return False
def is_hexagonal(h): # is_hexagonal check if the given number is hexagonal
if (1+(8*h+1)**0.5) % 4 == 0:
return True
return False
i = 286 # iterator start after 285
while True: # loop for iterating
triangle = i*(i+1)/2
if is_pentagonal(triangle) and is_hexagonal(triangle):
print (triangle)
break
i += 1
end_time = time.time() #Time at the end of execution
print ("Time of program execution:", (end_time - start_time)) # Time of program execution
# Solution 2
# import time
# start_time = time.time() #Time at the start of program execution
# def generate_triangle_number(n):
# return(n*(n+1)/2)
# def generate_pentagonal_number(n):
# return n*((3*n)-1)/2
# def generate_hexagonal_number(n):
# return n*(2*n-1)
# def main():
# triangle_numbers = [1]
# pentagonal_numbers = [1]
# triangle_n = 2
# pentagonal_n = 2
# hexagonal_n = 2
# while True:
# hexagonal_number = generate_hexagonal_number(hexagonal_n)
# hexagonal_n += 1
# while hexagonal_number > triangle_numbers[-1]:
# triangle_numbers.append(generate_triangle_number(triangle_n))
# triangle_n += 1
# while hexagonal_number > pentagonal_numbers[-1]:
# pentagonal_numbers.append(generate_pentagonal_number(pentagonal_n))
# pentagonal_n += 1
# if hexagonal_number in triangle_numbers and hexagonal_number in pentagonal_numbers:
# print(hexagonal_number)
# end_time = time.time() #Time at the end of execution
# print ("Time of program execution:", (end_time - start_time)) # Time of program execution
# main()
### Answer: 1533776805