aboutsummaryrefslogtreecommitdiff
path: root/challenge-169/adam-russell/java/ch-1.java
diff options
context:
space:
mode:
authordrbaggy <js5@sanger.ac.uk>2022-06-20 06:38:34 +0100
committerdrbaggy <js5@sanger.ac.uk>2022-06-20 06:38:34 +0100
commitcf74c017563b79bd9e1cceb10990bf13e40125f7 (patch)
tree2d4ab159f92f5651a4e6fd3262e259adec31040e /challenge-169/adam-russell/java/ch-1.java
parent26e9c6ce6f6f1815334d8a6e6599644b5196c7ac (diff)
parentb13601bf76ae50a91eae332a5faf08c99ad6300f (diff)
downloadperlweeklychallenge-club-cf74c017563b79bd9e1cceb10990bf13e40125f7.tar.gz
perlweeklychallenge-club-cf74c017563b79bd9e1cceb10990bf13e40125f7.tar.bz2
perlweeklychallenge-club-cf74c017563b79bd9e1cceb10990bf13e40125f7.zip
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'challenge-169/adam-russell/java/ch-1.java')
-rw-r--r--challenge-169/adam-russell/java/ch-1.java44
1 files changed, 44 insertions, 0 deletions
diff --git a/challenge-169/adam-russell/java/ch-1.java b/challenge-169/adam-russell/java/ch-1.java
new file mode 100644
index 0000000000..09cdd62612
--- /dev/null
+++ b/challenge-169/adam-russell/java/ch-1.java
@@ -0,0 +1,44 @@
+import java.util.ArrayList;
+
+class Brilliant{
+ private static ArrayList primeFactors(long n){
+ ArrayList factors = new ArrayList();
+ while (n % 2 == 0){
+ factors.add(new Long(2));
+ n = n / 2;
+ }
+ for(long i = 3; i <= Math.sqrt(n); i = i + 2){
+ while (n % i == 0){
+ factors.add(new Long(i));
+ n = n / i;
+ }
+ }
+ if(n > 2)
+ factors.add(new Long(n));
+ return factors;
+ }
+
+ private static boolean isBrilliant(int n){
+ ArrayList factors = primeFactors(n);
+ return factors.size() == 2 && ((Long)factors.get(0)).toString().length() == ((Long)factors.get(1)).toString().length();
+ }
+
+ public static ArrayList nBrilliants(int n){
+ ArrayList brilliants = new ArrayList();
+ int i = 0;
+ do{
+ i++;
+ if(isBrilliant(i))
+ brilliants.add(new Integer(i));
+ }while(brilliants.size() < n);
+ return brilliants;
+ }
+
+ public static void main(String[] args){
+ ArrayList brilliants = Brilliant.nBrilliants(20);
+ for(int i = 0; i < brilliants.size() - 1; i++){
+ System.out.print(brilliants.get(i) + ", ");
+ }
+ System.out.println(brilliants.get(brilliants.size() - 1));
+ }
+} \ No newline at end of file