使用.split时的领先空间

时间:2012-10-04 17:59:40

标签: java string tokenize

我有一个指定来修改我的教科书中的程序。程序从用户获取输入字符串,然后响应输入的单词数。我的任务是将其更改为字符计数而不是字数。我有这个工作正常,但是当我使用.split对字符进行标记时,我在数组中获得了一个领先的空间可以解释为什么吗?

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.Set;
import java.util.TreeSet;

/**
*
* @author Frank
*/
public class LetterCounting 
{
    public static void main( String[] args )
   {
      // create HashMap to store String keys and Integer values
      Map< String, Integer > myMap = new HashMap< String, Integer >(); 

      createMap( myMap ); // create map based on user input
      displayMap( myMap ); // display map content
   } // end main

   // create map from user input
   private static void createMap( Map< String, Integer > map ) 
   {
      Scanner scanner = new Scanner( System.in ); // create scanner
      System.out.println( "Enter a string:" ); // prompt for user input
      String input = scanner.nextLine();

      // tokenize the input
      String letters = input.replaceAll("\\s", "");
      String[] tokens = letters.split( "" );

      // processing input text 
      for ( String token : tokens ) 
      {
         String word = token.toLowerCase(); // get lowercase word

         // if the map contains the word
         if ( map.containsKey( word ) ) // is word in map
         {
            int count = map.get( word ); // get current count
            map.put( word, count + 1 ); // increment count
         } // end if
         else 
            map.put( word, 1 ); // add new word with a count of 1 to map
      } // end for
   } // end method createMap

   // display map content
   private static void displayMap( Map< String, Integer > map ) 
   {      
      Set< String > keys = map.keySet(); // get keys

      // sort keys
      TreeSet< String > sortedKeys = new TreeSet< String >( keys );

      System.out.println( "\nMap contains:\nKey\t\tValue" );

      // generate output for each key in map
      for ( String key : sortedKeys )
         System.out.printf( "%-10s%10s\n", key, map.get( key ) );

      System.out.printf( 
         "\nsize: %d\nisEmpty: %b\n", map.size(), map.isEmpty() );
   } // end method displayMap
} // end class WordTypeCount

我有来自netbeans的dubug数据的屏幕截图,但我没有足够的声誉来发布它。如果有人想看到它让我知道,我可以发送给你。

提前感谢您的意见。

2 个答案:

答案 0 :(得分:0)

为什么不尝试replaceAll(regex, replacement)方法并编写如下的简单代码?

    Scanner scanner = new Scanner( System.in ); // create scanner
    System.out.println( "Enter a string:" ); // prompt for user input
    String inputString = scanner.nextLine();
    System.out.println(inputString);
    System.out.println(inputString.length());
    String truncatedString = inputString.replaceAll(" ", "");
    System.out.println(truncatedString);
    System.out.println(truncatedString.length());

答案 1 :(得分:0)

String.split()使用正则表达式进行拆分。您可以使用StringUtils library中的一个splitXYZ()方法,它可以将字符串作为分隔符使用,并产生更可预测的结果。