Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,844 questions

51,765 answers

573 users

How to find the longest repeating substring in a string with Scala

1 Answer

0 votes
object LongestRepeatingSubstring {

  // Function to find the longest common prefix between two strings
  def longestCommonPrefix(sub1: String, sub2: String): String = {
    val minLen = math.min(sub1.length, sub2.length)

    for (i <- 0 until minLen) {
      if (sub1(i) != sub2(i)) {
        return sub1.substring(0, i)
      }
    }

    sub1.substring(0, minLen)
  }

  // Function to find the longest repeating substring
  def longestRepeatingSubstring(s: String): String = {
    var lrs = ""
    val size = s.length

    for (i <- 0 until size) {
      for (j <- i + 1 until size) {
        val lcp = longestCommonPrefix(s.substring(i), s.substring(j))
        if (lcp.length > lrs.length) {
          lrs = lcp
        }
      }
    }

    lrs
  }

  def main(args: Array[String]): Unit = {
    val s = "javascriptpythonphpjavacdartcppjavacsharpscala"
    
    println(longestRepeatingSubstring(s))
  }
}



/*
run:

pjavac

*/

 



answered Sep 23, 2025 by avibootz
edited Sep 23, 2025 by avibootz
...