aboutsummaryrefslogtreecommitdiff
path: root/challenge-256/luca-ferrari/pljava/src/main/java/Task1.java
diff options
context:
space:
mode:
authorMohammad Sajid Anwar <Mohammad.Anwar@yahoo.com>2024-02-15 19:07:15 +0000
committerGitHub <noreply@github.com>2024-02-15 19:07:15 +0000
commitd94684a52764452af4edbb2a33b7d409306e271c (patch)
tree0e4a7052c4c740d03ef90644e220981492e502cf /challenge-256/luca-ferrari/pljava/src/main/java/Task1.java
parente515224a439c9525a7e7cb7d33fc4b4c9af9785e (diff)
parent0cc3d19f45790123a25f7f33d9c5b3b239a48c5f (diff)
downloadperlweeklychallenge-club-d94684a52764452af4edbb2a33b7d409306e271c.tar.gz
perlweeklychallenge-club-d94684a52764452af4edbb2a33b7d409306e271c.tar.bz2
perlweeklychallenge-club-d94684a52764452af4edbb2a33b7d409306e271c.zip
Merge pull request #9587 from fluca1978/PWC256
PWC 256
Diffstat (limited to 'challenge-256/luca-ferrari/pljava/src/main/java/Task1.java')
-rw-r--r--challenge-256/luca-ferrari/pljava/src/main/java/Task1.java70
1 files changed, 70 insertions, 0 deletions
diff --git a/challenge-256/luca-ferrari/pljava/src/main/java/Task1.java b/challenge-256/luca-ferrari/pljava/src/main/java/Task1.java
new file mode 100644
index 0000000000..f532901d6e
--- /dev/null
+++ b/challenge-256/luca-ferrari/pljava/src/main/java/Task1.java
@@ -0,0 +1,70 @@
+package PWC256;
+
+/**
+ * PL/Java implementation for PWC 256
+ * Task 1
+ * See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-256>
+ *
+ *
+ * To compile on the local machine:
+
+ $ export JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64/ # if not already set
+ $ mvn clean build
+ $ scp target/PWC256.jar luca@venkman:/tmp
+
+
+ * To install into PostgreSQL execute:
+
+ select sqlj.install_jar( 'file:///tmp/PWC256.jar', 'PWC256', true );
+
+ select 256.task1_pljava();
+
+ and then to redeploy:
+
+ select sqlj.replace_jar( 'file:///tmp/PWC256.jar', 'PWC256', true );
+
+*/
+
+import org.postgresql.pljava.*;
+import org.postgresql.pljava.annotation.Function;
+import static org.postgresql.pljava.annotation.Function.Effects.IMMUTABLE;
+import static org.postgresql.pljava.annotation.Function.OnNullInput.RETURNS_NULL;
+
+import java.util.*;
+import java.sql.SQLException;
+import java.util.logging.*;
+
+public class Task1 {
+
+ private final static Logger logger = Logger.getAnonymousLogger();
+
+ @Function( schema = "256",
+ onNullInput = RETURNS_NULL,
+ effects = IMMUTABLE )
+ public static final int task1_pljava( String[] words ) throws SQLException {
+ logger.log( Level.INFO, "Entering task1_pljava" );
+
+ int max = 0;
+ for ( String current : words ) {
+ int count = count( current, words );
+ if ( count > max )
+ max = count;
+ }
+
+ return max;
+
+ }
+
+ private static final int count( String word, String[] words ) {
+ int count = 0;
+ StringBuilder builder = new StringBuilder();
+ builder.append( word );
+ word = builder.reverse().toString();
+
+ for ( String w : words )
+ if ( w.equals( word ) )
+ count++;
+
+ return count;
+ }
+}