227k views
24 votes
A student wants an algorithm to find the hardest spelling word in a list of vocabulary. They define hardest by the longest word.

Implement the findLongest method to return the longest String stored in the parameter array of Strings named words (you may assume that words is not empty). If several Strings have the same length it should print the first String in list with the longest length.

For example, if the following array were declared:

String[] spellingList = {"high", "every", "nearing", "checking", "food ", "stand", "value", "best", "energy", "add", "grand", "notation", "abducted", "food ", "stand"};
The method call findLongest(spellingList) would return the String "checking".

Use the runner class to test this method: do not add a main method to your code in the U6_L3_Activity_One.java file or it will not be scored correctly.

Hint - this algorithm is very similar to the algorithms you have seen to find maximum/minimum values in unit 4. You need a variable which will keep track of the longest word in the array (either directly or as the array index of that word). Start this variable off with a sensible value, update it whenever a longer word is found, then return the longest word at the end.

User Lahsrah
by
4.7k points

1 Answer

3 votes

Answer:

Initialize the “longest word” by an empty string and update it when a longer word is found

Step-by-step explanation:

import java.util.stream.Stream;

public static String findLongest(String[] spellingList) {

return Stream.of(spellingList).reduce("", (longestWord, word) -> (

longestWord.length() < word.length() ? word : longestWord

));

}

User Ahmad Ragab
by
4.6k points