nCr in Java
This commit is contained in:
parent
c20f5e2cdb
commit
4b71f72875
7 changed files with 52 additions and 12 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -2,3 +2,4 @@
|
||||||
venv
|
venv
|
||||||
private
|
private
|
||||||
__pycache__
|
__pycache__
|
||||||
|
*.out
|
||||||
|
|
3
.vscode/settings.json
vendored
Normal file
3
.vscode/settings.json
vendored
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"java.project.sourcePaths": ["java"]
|
||||||
|
}
|
0
c/algorithms/binary-search.c
Normal file
0
c/algorithms/binary-search.c
Normal file
9
c/calculators/helpers/factorial.c
Normal file
9
c/calculators/helpers/factorial.c
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
int factorial(int n) {
|
||||||
|
int ans = 1;
|
||||||
|
|
||||||
|
for (int i = 2; i <= n; i++) {
|
||||||
|
ans *= i;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ans;
|
||||||
|
}
|
|
@ -1,14 +1,5 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include "helpers/factorial.c"
|
||||||
int factorial(int n) {
|
|
||||||
int ans = 1;
|
|
||||||
|
|
||||||
for (int i = 2; i <= n; i++) {
|
|
||||||
ans *= i;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ans;
|
|
||||||
}
|
|
||||||
|
|
||||||
int nCr(int n, int r) {
|
int nCr(int n, int r) {
|
||||||
return factorial(n) / factorial(r) * factorial(n - r);
|
return factorial(n) / factorial(r) * factorial(n - r);
|
||||||
|
|
35
java/calculators/ncr.java
Normal file
35
java/calculators/ncr.java
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
package calculators;
|
||||||
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
class CombinationCalculator {
|
||||||
|
private static int factorial(int n) {
|
||||||
|
int res = 1;
|
||||||
|
|
||||||
|
for (int i = 2; i <= n; i++) {
|
||||||
|
res *= i;
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static int nCr(int n, int r) {
|
||||||
|
return factorial(n) / (factorial(r) * factorial(n - r));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
// Open a scanner and take the relevant inputs
|
||||||
|
Scanner scan = new Scanner(System.in);
|
||||||
|
|
||||||
|
System.out.print("Please input the value for n: ");
|
||||||
|
int n = scan.nextInt();
|
||||||
|
|
||||||
|
System.out.print("Please input the value for r: ");
|
||||||
|
int r = scan.nextInt();
|
||||||
|
|
||||||
|
// Close the scanner, and calculate the result
|
||||||
|
scan.close();
|
||||||
|
|
||||||
|
int result = nCr(n, r);
|
||||||
|
System.out.println(result);
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,8 +7,9 @@
|
||||||
|
|
||||||
### Table of contents
|
### Table of contents
|
||||||
|
|
||||||
- [Python](python)
|
- [Python](languages/python)
|
||||||
- [C](c)
|
- [C](languages/c)
|
||||||
|
- [Java](languages/java)
|
||||||
- [Project Euler](euler)
|
- [Project Euler](euler)
|
||||||
- [GCSE Computer Science](school/gcse)
|
- [GCSE Computer Science](school/gcse)
|
||||||
- [Royal Institute Computer Science Masterclass 2021](school/royal%20institute)
|
- [Royal Institute Computer Science Masterclass 2021](school/royal%20institute)
|
||||||
|
|
Loading…
Reference in a new issue