Problem 401 solution - Sum of squares of divisors
More...
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <inttypes.h>
|
#define | __STDC_FORMAT_MACROS |
|
#define | MOD_LIMIT (uint64_t)1e9 |
| modulo limit
|
|
#define | MAX_LENGTH 5000 |
| chunk size of array allocation
|
|
|
char | is_in (uint64_t N, uint64_t *D, uint64_t L) |
| Check if a number is present in given array. More...
|
|
uint64_t | get_divisors (uint64_t N, uint64_t *D) |
| Get all integer divisors of a number. More...
|
|
uint64_t | sigma2 (uint64_t N) |
| compute sum of squares of all integer factors of a number More...
|
|
uint64_t | sigma (uint64_t N) |
| sum of squares of factors of numbers from 1 thru N More...
|
|
int | main (int argc, char **argv) |
| Main function. More...
|
|
Problem 401 solution - Sum of squares of divisors
- Author
- Krishna Vedala
◆ get_divisors()
uint64_t get_divisors |
( |
uint64_t |
N, |
|
|
uint64_t * |
D |
|
) |
| |
Get all integer divisors of a number.
- Parameters
-
[in] | N | number to find divisors for |
[out] | D | array to store divisors in |
- Returns
- number of divisors found
60 for (i = 1; i * i <= N + 1; i++)
68 if (!
is_in(i, D, num))
73 if (!
is_in(q, D, num))
82 D = (uint64_t *)realloc(D,
MAX_LENGTH *
sizeof(uint64_t) << 1);
char is_in(uint64_t N, uint64_t *D, uint64_t L)
Check if a number is present in given array.
Definition: sol1.c:28
#define MAX_LENGTH
chunk size of array allocation
Definition: sol1.c:18
◆ is_in()
char is_in |
( |
uint64_t |
N, |
|
|
uint64_t * |
D, |
|
|
uint64_t |
L |
|
) |
| |
Check if a number is present in given array.
- Parameters
-
[in] | N | number to check |
[in] | D | array to check |
[in] | L | length of array |
- Returns
- 1 if present
-
0 if absent
31 for (i = 0; i <
L; i++)
◆ main()
int main |
( |
int |
argc, |
|
|
char ** |
argv |
|
) |
| |
Main function.
138 N = strtoll(argv[1], NULL, 10);
142 fprintf(stderr,
"Wrong number of input arguments!\n");
143 printf(
"Usage:\t ./sol1.c [N=1000]");
147 clock_t start_time = clock();
148 uint64_t result =
sigma(N);
149 double dtime = clock() - start_time;
151 printf(
"N = %" PRIu64
"\nSum: %" PRIu64
"\n", N, result);
152 printf(
"Time taken: %.4gms\n", dtime * 1e3 / CLOCKS_PER_SEC);
uint64_t sigma(uint64_t N)
sum of squares of factors of numbers from 1 thru N
Definition: sol1.c:114
◆ sigma()
uint64_t sigma |
( |
uint64_t |
N | ) |
|
sum of squares of factors of numbers from 1 thru N
121#pragma omp parallel for reduction(+ : sum)
123 for (i = 0; i <= N; i++)
uint64_t sigma2(uint64_t N)
compute sum of squares of all integer factors of a number
Definition: sol1.c:93
#define MOD_LIMIT
modulo limit
Definition: sol1.c:17
◆ sigma2()
uint64_t sigma2 |
( |
uint64_t |
N | ) |
|
compute sum of squares of all integer factors of a number
- Parameters
-
- Returns
- sum of squares
100 for (i = 1; i <
L; i++)
#define malloc(bytes)
This macro replace the standard malloc function with malloc_dbg.
Definition: malloc_dbg.h:18
#define free(ptr)
This macro replace the standard free function with free_dbg.
Definition: malloc_dbg.h:26
uint64_t get_divisors(uint64_t N, uint64_t *D)
Get all integer divisors of a number.
Definition: sol1.c:47