From 64c113b89b96b1cbdec8ba6b3323aeff77ca0c85 Mon Sep 17 00:00:00 2001 From: mjfernez Date: Sun, 16 Feb 2020 16:42:23 -0500 Subject: Added sumsq.c. Fixed pyhton solution for the same --- 06-Sum-Square-Difference/sumsq | Bin 0 -> 16616 bytes 06-Sum-Square-Difference/sumsq.c | 20 ++++++++++++++++++++ 06-Sum-Square-Difference/sumsq.py | 9 +++------ 3 files changed, 23 insertions(+), 6 deletions(-) create mode 100755 06-Sum-Square-Difference/sumsq create mode 100644 06-Sum-Square-Difference/sumsq.c (limited to '06-Sum-Square-Difference') diff --git a/06-Sum-Square-Difference/sumsq b/06-Sum-Square-Difference/sumsq new file mode 100755 index 0000000..8f8aa03 Binary files /dev/null and b/06-Sum-Square-Difference/sumsq differ diff --git a/06-Sum-Square-Difference/sumsq.c b/06-Sum-Square-Difference/sumsq.c new file mode 100644 index 0000000..1de2ebe --- /dev/null +++ b/06-Sum-Square-Difference/sumsq.c @@ -0,0 +1,20 @@ +#include + +// Find the difference between (1+2+3+...+100)^2 and (1^2+2^2+3^2+...+100^2) +// I used another math trick here: +// The sum up to a number can be found using Gauss' Trick: +// 1 + 2 + 3 + ... + 10 -> (1+9) + (2+8) + (3+7) + (4+6) + 10 + 5 -> 5*10 +5 +// In general : (n/2)(n+1) + +int main() { + long sqsum = 50 * 101; + sqsum *=sqsum; + printf("The square of the sum is: %lu\n", sqsum); + long sumsq = 0; + for(long i = 1; i <= 100; i++) { + sumsq += i * i; + } + printf("The sum of the squares is: %lu\n", sumsq); + printf("Difference: %lu\n", sqsum - sumsq); + return 0; +} diff --git a/06-Sum-Square-Difference/sumsq.py b/06-Sum-Square-Difference/sumsq.py index fdd43e4..6882eb6 100644 --- a/06-Sum-Square-Difference/sumsq.py +++ b/06-Sum-Square-Difference/sumsq.py @@ -10,14 +10,11 @@ import PIL import math -nums = range(1, 11) -numsq = range(1, 11) +nums = range(1, 101) +numsq = [] for i in nums: - i = i*i - -print(nums) -print(numsq) + numsq.append(i*i) sum1 = (sum(nums)**2) sum2 = (sum(numsq)) -- cgit v1.2.3