4.3. Loops and Strings

Loops are often used for String Traversals or String Processing where the code steps through a string character by character. In lesson 2.6 and 2.7, we learned to use String objects and built-in string methods to process strings. In this lesson, we will write our own loops to process strings.

Remember that strings are a sequence of characters where each character is at a position or index starting at 0.

a string with the position (index) shown above each character

Figure 1: A string with the position (index) shown above each character

Note

The first character in a Java String is at index 0 and the last characters is at length() - 1. So loops processing Strings should start at 0!

The String methods (covered in lesson 2.7 and given in the AP CS A Java Quick Reference Sheet) that are most often used to process strings are:

Google has been scanning old books and then using software to read the scanned text. But, the software can get things mixed up like using the number 1 for the letter l. Try the code below that cleans up scanning mistakes like this.

coding exercise Coding Exercise

The following code loops through a string replacing all 1’s with l’s. Trace through the code below with a partner and explain how it works on the given message. You can run it line by line in the Java visualizer. Note that indexOf here can work repeatedly to find the next occurrence of a 1 because they are replaced as soon as they are found. Change the code to add code for a counter variable to count the number of 1’s replaced in the message and print it out. Change the message to have more mistakes with 1’s to test it.

exercise Check Your Understanding

        4-3-1: The following method has the correct code to return a string with all a's removed, but the code is mixed up.  Drag the blocks from the left area into the correct order in the right area.  Click on the "Check Me" button to check your solution.public static String remA(String s)
{
---
   int index = 0;
---
   // while still an a in str
   while (s.indexOf("a") >= 0)
   {
---
      // Find the next index for an a
      index = s.indexOf("a");
---
      // Remove the a at index by concatenating
      // substring up to index and then rest of the string.
      s = s.substring(0,index) +
          s.substring(index+1);
---
   } // end loop
---
   return s;
---
} // end method
        

While loops are often used with strings when you are looking for a certain character or substring in a string and do not know how many times the loop needs to run.

For-loops can also be used to process strings in situations where you know you will visit every character. Here is a for-loop that creates a new string that reverses the string. Remember to start the loop at 0 and use length() for the ending condition.

coding exercise Coding Exercise

Here is a for-loop from 0 to length() that reverses a string. You can also run this in this Java visualizer link. What would happen if you started the loop at 1 instead? What would happen if you used <= instead of <? What would happen if you changed the order in which you added the ithLetter in line 12?

exercise Check Your Understanding

        4-3-2: The following main method has the correct code to count the number of e's in a string, but the code is mixed up.  Drag the blocks from the left area into the correct order in the right area.  Click on the "Check Me" button to check your solution.public static void main(String[] args)
{
---
   String message = "e is the most frequent English letter.";
   int count = 0;
---
   for(int i=0; i < message.length(); i++)
   {
---
      if (message.substring(i,i+1).equalsIgnoreCase("e"))
---
         count++;
---
   }
---
     System.out.println(count);
---
}
        

4.3.1. groupwork Programming Challenge : String Replacement Cats and Dogs

Cat or Dog

Are you a cat person or a dog person? The code below prints a nice message about cats, but if you’re a dog person, you might not agree.

  1. Write some code below that changes every occurrence of “cat” to “dog” in the message. This code will be more like the first program in this lesson where we replaced 1’s with l’s.

  2. Also, add a counter to count the number of replacements and print it out.

  3. (Optional - challenging) What if you like both cats and dogs? After you replace “cat” with “dog”, add another loop that looks for the word “dogs” and adds ” and cats” to it. Do not replace “dog”, just replace “dogs”. This will just replace the first sentence in the example below but you can add other sentences to test. For this loop, you will need to use a special version of indexOf that searches from a given index, so that you don’t end up with an infinite loop that keeps finding the first “dogs”. Make sure you add a variable fromIndex that is initialized to 0 and that is changed each time through the loop to skip over the last word that was found.

    • int indexOf(String target, int fromIndex) searches left-to-right for the target substring, but starts the search at the given fromIndex. You are not required to know this version of indexOf for the AP CS A exam, but you can use it (and any valid Java code) in the Free Response Questions.

4.3.2. Summary

  • Loops can be used to traverse or process a string.

There are standard algorithms that utilize String traversals to:

  • Find if one or more substrings has a particular property

  • Determine the number of substrings that meet specific criteria

  • Create a new string with the characters reversed

For more practice with string processing, see the Free Response Question in the Practice and Summary section of this unit.

You have attempted of activities on this page
Next Section - 4.4. Nested For Loops