aboutsummaryrefslogtreecommitdiffstats
path: root/05-Smallest-Multiple
diff options
context:
space:
mode:
authormjfernez <mjfernez@gmail.com>2020-02-09 15:16:26 -0500
committermjfernez <mjfernez@gmail.com>2020-02-09 15:16:26 -0500
commit93ea7fe5957b62f18e8fbd17a21696bd7de6332d (patch)
treed90aed60d687bcf195f1150777f37cbe8a149814 /05-Smallest-Multiple
parent125ec5bc3d8bfc224b7d32bcfbbc37b9fb5d441f (diff)
downloadProject_Euler_Solutions-93ea7fe5957b62f18e8fbd17a21696bd7de6332d.tar.gz
Organized everything, update README
Diffstat (limited to '05-Smallest-Multiple')
-rwxr-xr-x05-Smallest-Multiple/smallmultbin0 -> 16648 bytes
-rw-r--r--05-Smallest-Multiple/smallmult.c23
-rw-r--r--05-Smallest-Multiple/smallmult.py29
3 files changed, 52 insertions, 0 deletions
diff --git a/05-Smallest-Multiple/smallmult b/05-Smallest-Multiple/smallmult
new file mode 100755
index 0000000..5f4e692
--- /dev/null
+++ b/05-Smallest-Multiple/smallmult
Binary files differ
diff --git a/05-Smallest-Multiple/smallmult.c b/05-Smallest-Multiple/smallmult.c
new file mode 100644
index 0000000..302f19b
--- /dev/null
+++ b/05-Smallest-Multiple/smallmult.c
@@ -0,0 +1,23 @@
+#include <stdlib.h>
+#include <stdio.h>
+
+// num: the number to divide
+// gd: the greatest divisor to count up to
+int isDivisible(int num, int gd){
+ int divisible = 1;
+ for(int i = 1; i < gd; i++){
+ if(num % i != 0)
+ divisible = 0;
+ }
+ return divisible;
+}
+
+int main(){
+ int found = 0;
+ int start = 2520;
+ while(!found){
+ start += 20;
+ found = isDivisible(start, 20);
+ }
+ printf("%d\n", start);
+}
diff --git a/05-Smallest-Multiple/smallmult.py b/05-Smallest-Multiple/smallmult.py
new file mode 100644
index 0000000..a8a6344
--- /dev/null
+++ b/05-Smallest-Multiple/smallmult.py
@@ -0,0 +1,29 @@
+# Problem 5 smallest multiple
+# 2520 is the smallest number that can be divided by
+# each of the numbers from 1 to 10 without any remainder.
+# What is the smallest positive number that is evenly divisible
+# by all of the numbers from 1 to 20?
+
+import PIL
+import math
+
+
+def isDivisible(num, divisors):
+ divisible = True
+ for j in divisors:
+ if(num % j != 0):
+ divisible = False
+ break
+ return divisible
+
+
+divs = range(1, 21)
+
+found = False
+start = 2520
+while (not found):
+ start += 20
+ found = isDivisible(start, divs)
+
+print(start)
+print(str(isDivisible(start, divs)))