Module: AP COMPUTER SCIENCE SECTION II 2014


Problem

3/3

AP COMPUTER SCIENCE A 2014 FREE-RESPONSE QUESTION - Word Scrambler

Problem

Consider the following partial declaration for a WordScrambler class. The constructor for the WordScrambler class takes an even-length array of String objects and initializes the instance variable scrambledWords.
public class WordScrambler
{
    private String[] scrambledWords;
    /** @param wordArr an array of String objects
     * Precondition: wordArr.length is even
     */
    public WordScrambler(String[] wordArr)
    {
        scrambledWords = mixedWords(wordArr);
    }
    /** @param word1 a String of characters
     * @param word2 a String of characters
     * @return a String that contains the first half of word1 and the second half of word2
     */
    private String recombine(String word1, String word2)
    { /* to be implemented in part (a) */ }
    /** @param words an array of String objects
     * Precondition: words.length is even
     * @return an array of String objects created by recombining pairs of strings in array words
     * Postcondition: the length of the returned array is words.length
     */
    private String[] mixedWords(String[] words)
    { /* to be implemented in part (b) */ }
// There may be instance variables, constructors, and methods that are not shown.
}    

a) Write the WordScrambler method recombine. This method returns a String created from its two String parameters as follows.
  • take the first half of word1
  • take the second half of word2
  • concatenate the two halves and return the new string.
For example, the following table shows some results of calling recombine. Note that if a word has an odd number of letters, the second half of the word contains the extra letter.
word1 word2 recombine(word1, word2)
"apple" "pear" "apar"
"pear" "apple" "peple"

Complete method recombine below.
/** @param word1 a String of characters
* @param word2 a String of characters
* @return a String that contains the first half of word1 and the second half of word2
*/
private String recombine(String word1, String word2)

(b) Write the WordScrambler method mixedWords. This method creates and returns a new array of String objects as follows.
It takes the first pair of strings in words and combines them to produce a pair of strings to be included in the array returned by the method. If this pair of strings consists of w1 and w2, the method should include the result of calling recombine with w1 and w2 as arguments and should also include the result of calling recombine with w2 and w1 as arguments. The next two strings, if they exist, would form the next pair to be processed by this method. The method should continue until all the strings in words have been processed in this way and the new array has been filled. For example, if the array words contains the following elements:

{"apple", "pear", "this", "cat"}
then the call mixedWords(words) should return the following array.
{"apar", "peple", "that", "cis"}
In writing mixedWords, you may call recombine. Assume that recombine works as specified,
regardless of what you wrote in part (a).

Complete method mixedWords below.

/** @param words an array of String objects
* Precondition: words.length is even
* @return an array of String objects created by recombining pairs of strings in array words
* Postcondition: the length of the returned array is words.length
*/
private String[] mixedWords(String[] words)