aboutsummaryrefslogtreecommitdiff
path: root/challenge-325/deadmarshal/java
diff options
context:
space:
mode:
authorMohammad Sajid Anwar <Mohammad.Anwar@yahoo.com>2025-06-10 09:23:35 +0100
committerGitHub <noreply@github.com>2025-06-10 09:23:35 +0100
commit7ad8fdb1ba3d67e7d46ff5ed9527c200ab5dbc0e (patch)
tree42245290f03bb21105d07b4ce5153c1c6b602cf4 /challenge-325/deadmarshal/java
parentf9a0da9465d4b6745ede068698d1d59125a8a7ab (diff)
parent8f7edcdf6fd5d1ecc837c050d7ca3298827fb4ac (diff)
downloadperlweeklychallenge-club-7ad8fdb1ba3d67e7d46ff5ed9527c200ab5dbc0e.tar.gz
perlweeklychallenge-club-7ad8fdb1ba3d67e7d46ff5ed9527c200ab5dbc0e.tar.bz2
perlweeklychallenge-club-7ad8fdb1ba3d67e7d46ff5ed9527c200ab5dbc0e.zip
Merge pull request #12159 from deadmarshal/TWC325
TWC325
Diffstat (limited to 'challenge-325/deadmarshal/java')
-rw-r--r--challenge-325/deadmarshal/java/Ch1.java20
-rw-r--r--challenge-325/deadmarshal/java/Ch2.java21
2 files changed, 41 insertions, 0 deletions
diff --git a/challenge-325/deadmarshal/java/Ch1.java b/challenge-325/deadmarshal/java/Ch1.java
new file mode 100644
index 0000000000..f1f27e332c
--- /dev/null
+++ b/challenge-325/deadmarshal/java/Ch1.java
@@ -0,0 +1,20 @@
+public class Ch1 {
+ public static void main(String[] args) {
+ System.out.println(consecutive_one(new int[]{0, 1, 1, 0, 1, 1, 1}));
+ System.out.println(consecutive_one(new int[]{0, 0, 0, 0}));
+ System.out.println(consecutive_one(new int[]{1, 0, 1, 0, 1, 1}));
+ }
+
+ private static int consecutive_one(int[] arr) {
+ int count = 0, res = 0;
+ for (int e : arr) {
+ if (e == 1) count++;
+ else {
+ res = Math.max(res, count);
+ count = 0;
+ }
+ }
+ return Math.max(count, res);
+ }
+}
+
diff --git a/challenge-325/deadmarshal/java/Ch2.java b/challenge-325/deadmarshal/java/Ch2.java
new file mode 100644
index 0000000000..353b6f6506
--- /dev/null
+++ b/challenge-325/deadmarshal/java/Ch2.java
@@ -0,0 +1,21 @@
+import java.util.Arrays;
+import java.util.Stack;
+
+public class Ch2 {
+ public static void main(String[] args) {
+ System.out.println(Arrays.toString(final_price(new int[]{8, 4, 6, 2, 3})));
+ System.out.println(Arrays.toString(final_price(new int[]{1, 2, 3, 4, 5})));
+ System.out.println(Arrays.toString(final_price(new int[]{7, 1, 1, 5})));
+ }
+
+ private static int[] final_price(int[] arr) {
+ Stack<Integer> stack = new Stack<>();
+ for (int i = 0; i < arr.length; ++i) {
+ while (!stack.isEmpty() && arr[stack.peek()] >= arr[i])
+ arr[stack.pop()] -= arr[i];
+ stack.push(i);
+ }
+ return arr;
+ }
+}
+