aboutsummaryrefslogtreecommitdiff
path: root/challenge-238/deadmarshal/java/Ch2.java
diff options
context:
space:
mode:
authorMohammad Sajid Anwar <Mohammad.Anwar@yahoo.com>2023-10-12 21:13:29 +0100
committerGitHub <noreply@github.com>2023-10-12 21:13:29 +0100
commit564829406b4704b821beb8940fe05fea5f302b01 (patch)
tree837a50917d24027d2ca837ba7128c35b96c47266 /challenge-238/deadmarshal/java/Ch2.java
parent0c4b179a018dfe100576dd2c147fb734227288e8 (diff)
parenta6233090f6700d2c4b34d30c9e50c6b113b722d2 (diff)
downloadperlweeklychallenge-club-564829406b4704b821beb8940fe05fea5f302b01.tar.gz
perlweeklychallenge-club-564829406b4704b821beb8940fe05fea5f302b01.tar.bz2
perlweeklychallenge-club-564829406b4704b821beb8940fe05fea5f302b01.zip
Merge pull request #8860 from deadmarshal/TWC238
TWC238
Diffstat (limited to 'challenge-238/deadmarshal/java/Ch2.java')
-rw-r--r--challenge-238/deadmarshal/java/Ch2.java46
1 files changed, 46 insertions, 0 deletions
diff --git a/challenge-238/deadmarshal/java/Ch2.java b/challenge-238/deadmarshal/java/Ch2.java
new file mode 100644
index 0000000000..0a71d431a4
--- /dev/null
+++ b/challenge-238/deadmarshal/java/Ch2.java
@@ -0,0 +1,46 @@
+import java.util.ArrayList;
+import java.util.Comparator;
+import java.util.List;
+
+public class Ch2 {
+ public static void main(String[] args) {
+ ArrayList<Integer> list1 = new ArrayList<>(List.of(15,99,1,34));
+ ArrayList<Integer> list2 = new ArrayList<>(List.of(50,25,33,22));
+ persistence_sort(list1);
+ persistence_sort(list2);
+ System.out.println(list1);
+ System.out.println(list2);
+ }
+
+ private static int product(int n) {
+ int prod = 1;
+ while(n > 0)
+ {
+ prod *= n % 10;
+ n /= 10;
+ }
+ return prod;
+ }
+
+ private static int helper(int n) {
+ int sum = 0;
+ while(n >= 10)
+ {
+ sum++;
+ n = product(n);
+ }
+ return sum;
+ }
+
+ private static void persistence_sort(List<Integer> list) {
+ list.sort(new Comparator<Integer>() {
+ @Override
+ public int compare(Integer a, Integer b) {
+ int ha = helper(a);
+ int hb = helper(b);
+ return ha == hb ? Integer.compare(a,b) :
+ Integer.compare(ha,hb);
+ }});
+ }
+}
+