diff options
| author | Mohammad Sajid Anwar <Mohammad.Anwar@yahoo.com> | 2025-05-13 13:20:55 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-05-13 13:20:55 +0100 |
| commit | 8ac9237f3ee78a2c281f85e001987694a8f535e7 (patch) | |
| tree | 309513781cbe22982942efebbbf96df219e414ec /challenge-321/deadmarshal/java/Ch2.java | |
| parent | 9f9212572f40fc04654ca829356baedbf9acecb1 (diff) | |
| parent | 83efa41a4137d09f36c8b4f2fbc117aec205f448 (diff) | |
| download | perlweeklychallenge-club-8ac9237f3ee78a2c281f85e001987694a8f535e7.tar.gz perlweeklychallenge-club-8ac9237f3ee78a2c281f85e001987694a8f535e7.tar.bz2 perlweeklychallenge-club-8ac9237f3ee78a2c281f85e001987694a8f535e7.zip | |
Merge pull request #12017 from deadmarshal/TWC321
TWC321
Diffstat (limited to 'challenge-321/deadmarshal/java/Ch2.java')
| -rw-r--r-- | challenge-321/deadmarshal/java/Ch2.java | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/challenge-321/deadmarshal/java/Ch2.java b/challenge-321/deadmarshal/java/Ch2.java new file mode 100644 index 0000000000..8d92e9bc6e --- /dev/null +++ b/challenge-321/deadmarshal/java/Ch2.java @@ -0,0 +1,41 @@ +public class Ch2 { + public static void main(String[] args) { + System.out.println(backspace_compare("ab#c", "ad#c")); + System.out.println(backspace_compare("ab##", "a#b#")); + System.out.println(backspace_compare("a#b", "c")); + } + + private static boolean backspace_compare(String s1, String s2) { + int i = s1.length() - 1, j = s2.length() - 1; + int skip1 = 0, skip2 = 0; + for (; i >= 0 || j >= 0; --i, --j) { + while (i >= 0) { + if (s1.charAt(i) == '#') { + ++skip1; + --i; + } else if (skip1 > 0) { + --skip1; + --i; + } else { + break; + } + } + while (j >= 0) { + if (s2.charAt(j) == '#') { + ++skip2; + --j; + } else if (skip2 > 0) { + --skip2; + --j; + } else { + break; + } + } + if (i >= 0 && j >= 0) { + if (s1.charAt(i) != s2.charAt(j)) return false; + } else if (i >= 0 || j >= 0) return false; + } + return true; + } +} + |
