aboutsummaryrefslogtreecommitdiff
path: root/challenge-238/deadmarshal/java/Ch2.java
diff options
context:
space:
mode:
author冯昶 <fengchang@novel-supertv.com>2023-10-16 16:39:52 +0800
committer冯昶 <fengchang@novel-supertv.com>2023-10-16 16:39:52 +0800
commit50febb3c84c6adc42c33005f8f85ae229ddde328 (patch)
treee41f1a1878b94c7a38e1de0bf18031a83f7f5254 /challenge-238/deadmarshal/java/Ch2.java
parent39dda85aa681328178935c4bc0c0fe87c9e63f60 (diff)
parentafac53ab966abe7e14039640d054f82eb323097c (diff)
downloadperlweeklychallenge-club-50febb3c84c6adc42c33005f8f85ae229ddde328.tar.gz
perlweeklychallenge-club-50febb3c84c6adc42c33005f8f85ae229ddde328.tar.bz2
perlweeklychallenge-club-50febb3c84c6adc42c33005f8f85ae229ddde328.zip
Merge remote-tracking branch 'upstream/master'
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);
+ }});
+ }
+}
+