diff options
author | Iru Cai <mytbk920423@gmail.com> | 2018-05-26 14:27:47 +0800 |
---|---|---|
committer | Iru Cai <mytbk920423@gmail.com> | 2018-05-26 14:27:47 +0800 |
commit | c98d66aca04d0d839833b6b81bf249822c4ca350 (patch) | |
tree | dafe2a5a36384ab7feab7187271b4be9bba4fdc3 /euler53.c | |
parent | d5c645bf83f144838e84b21e4941a0e42b0a9a61 (diff) | |
download | project_euler-c98d66aca04d0d839833b6b81bf249822c4ca350.tar.xz |
53, 55, 56
Diffstat (limited to 'euler53.c')
-rw-r--r-- | euler53.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/euler53.c b/euler53.c new file mode 100644 index 0000000..3e71c87 --- /dev/null +++ b/euler53.c @@ -0,0 +1,26 @@ +#include <stdio.h> + +/* number of r s.t. C(n, r)>x */ +int nr_ncr_bigger(int n, int x) +{ + int prod = 1; + int r = 0; + + while (prod <= x && r*2 < n) { + r++; + prod = prod * (n-r+1) / r; + } + + if (prod <= x) + return 0; + else + return n - r*2 + 1; +} + +int main() +{ + int cnt = 0; + for (int i = 1; i <= 100; i++) + cnt += nr_ncr_bigger(i, 1000000); + printf("%d\n", cnt); +} |