问题

1.问题:以下字符串生成器的初始容量是多少?

  1. StringBuilder sb = new StringBuilder("Able was I ere I saw Elba.");

答案:容量是初始字符串的长度+ 16:26 + 16 = 42。
2.考虑以下字符串:

  1. String hannah = "Did Hannah see bees? Hannah did.";

a.问题:表达式hannah.length()显示的值是多少?
答: 32。

b.问题:方法调用hannah.charAt(12)返回的值是多少?
答: e

c.问题:编写一个表达式,该表达式引用由hannah所引用的字符串中的字母b
答: hannah.charAt(15)

3.问题:以下表达式返回的字符串多长?字符串是什么?

  1. "Was it a car or a cat I saw?".substring(9, 12)

答:长度为3个字符:car。它不包括car后的空间。
4.问题:在下面的ComputeResult程序中,执行每条带编号的行后,result的值是多少?

  1. public class ComputeResult {
  2. public static void main(String[] args) {
  3. String original = "software";
  4. StringBuilder result = new StringBuilder("hi");
  5. int index = original.indexOf('a');
  6. /*1*/ result.setCharAt(0, original.charAt(0));
  7. /*2*/ result.setCharAt(1, original.charAt(original.length()-1));
  8. /*3*/ result.insert(1, original.charAt(4));
  9. /*4*/ result.append(original.substring(1,4));
  10. /*5*/ result.insert(3, (original.substring(index, index+2) + " "));
  11. System.out.println(result);
  12. }
  13. }

回答:

  1. si
  2. se
  3. swe
  4. sweoft
  5. swear oft

练习题

练习:展示两种将以下两个字符"Hi, mom."串连接在一起以得到字符串的方法:

  1. String hi = "Hi, ";
  2. String mom = "mom.";

答: hi.concat(mom)hi + mom
练习:编写一个程序,使用您的全名来计算您的姓名首字母并将其显示出来。
回答: ComputeInitials

  1. public class ComputeInitials {
  2. public static void main(String[] args) {
  3. String myName = "Fred F. Flintstone";
  4. StringBuffer myInitials = new StringBuffer();
  5. int length = myName.length();
  6. for (int i = 0; i < length; i++) {
  7. if (Character.isUpperCase(myName.charAt(i))) {
  8. myInitials.append(myName.charAt(i));
  9. }
  10. }
  11. System.out.println("My initials are: " + myInitials);
  12. }
  13. }

练习:字谜是通过一个单词或短语的字母换位而得到的另一个单词或短语;例如,“parliament”是“partial men”的字谜,“software”是“swear oft”的字谜。编写一个程序,弄清楚一个字符串是否是另一个字符串的字谜。该程序应忽略空格和标点符号。
回答: Anagram

  1. public class Anagram {
  2. public static boolean areAnagrams(String string1,
  3. String string2) {
  4. String workingCopy1 = removeJunk(string1);
  5. String workingCopy2 = removeJunk(string2);
  6. workingCopy1 = workingCopy1.toLowerCase();
  7. workingCopy2 = workingCopy2.toLowerCase();
  8. workingCopy1 = sort(workingCopy1);
  9. workingCopy2 = sort(workingCopy2);
  10. return workingCopy1.equals(workingCopy2);
  11. }
  12. protected static String removeJunk(String string) {
  13. int i, len = string.length();
  14. StringBuilder dest = new StringBuilder(len);
  15. char c;
  16. for (i = (len - 1); i >= 0; i--) {
  17. c = string.charAt(i);
  18. if (Character.isLetter(c)) {
  19. dest.append(c);
  20. }
  21. }
  22. return dest.toString();
  23. }
  24. protected static String sort(String string) {
  25. char[] charArray = string.toCharArray();
  26. java.util.Arrays.sort(charArray);
  27. return new String(charArray);
  28. }
  29. public static void main(String[] args) {
  30. String string1 = "Cosmo and Laine:";
  31. String string2 = "Maid, clean soon!";
  32. System.out.println();
  33. System.out.println("Testing whether the following "
  34. + "strings are anagrams:");
  35. System.out.println(" String 1: " + string1);
  36. System.out.println(" String 2: " + string2);
  37. System.out.println();
  38. if (areAnagrams(string1, string2)) {
  39. System.out.println("They ARE anagrams!");
  40. } else {
  41. System.out.println("They are NOT anagrams!");
  42. }
  43. System.out.println();
  44. }
  45. }