Skip to content

Commit

Permalink
day 137
Browse files Browse the repository at this point in the history
  • Loading branch information
jwardoin committed Aug 8, 2022
1 parent 2fc85bc commit 56744cf
Showing 1 changed file with 34 additions and 0 deletions.
34 changes: 34 additions & 0 deletions consecutiveStrings.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
// You are given an array(list) strarr of strings and an integer k. Your task is to return the first longest string consisting of k consecutive strings taken in the array.

// Examples:
// strarr = ["tree", "foling", "trashy", "blue", "abcdef", "uvwxyz"], k = 2

// Concatenate the consecutive strings of strarr by 2, we get:

// treefoling (length 10) concatenation of strarr[0] and strarr[1]
// folingtrashy (" 12) concatenation of strarr[1] and strarr[2]
// trashyblue (" 10) concatenation of strarr[2] and strarr[3]
// blueabcdef (" 10) concatenation of strarr[3] and strarr[4]
// abcdefuvwxyz (" 12) concatenation of strarr[4] and strarr[5]

// Two strings are the longest: "folingtrashy" and "abcdefuvwxyz".
// The first that came is "folingtrashy" so
// longest_consec(strarr, 2) should return "folingtrashy".

// In the same way:
// longest_consec(["zone", "abigail", "theta", "form", "libe", "zas", "theta", "abigail"], 2) --> "abigailtheta"
// n being the length of the string array, if n = 0 or k > n or k <= 0 return "" (return Nothing in Elm, "nothing" in Erlang).

// my original solution

function longestConsec(strarr, k) {
if(!strarr.length || k > strarr.length || k <= 0) return ""
let longest = ''
for(let i = 0; i <= strarr.length - k; i++){
let current = strarr.slice(i, i + k).join('')
if(current.length > longest.length) {
longest = current
}
}
return longest
}

0 comments on commit 56744cf

Please sign in to comment.