我正在尝试从 TreeMap 中的单个键中检索多个值。这个想法是每个键将链接到多个值并且应该是可搜索的。现在我遇到的麻烦是,当我只能从键中取回一个值时。
键是字符串,值是自定义对象,称为 Song。歌曲包含多种元素。目标是从每首歌曲中逐字提取歌词,并将每个单词用作键。然后该键链接到包含该键的每首歌曲(值)。
我已经在 StackOverFlow 和网络上搜索了一般的提示,并且我看到了一些,但没有任何东西可以直接解决我的绊脚石。我看到的一个想法是将值更改为某种数组或列表。明天当我的大脑恢复活力时,我可以试试。
无论如何,提前感谢任何提示和建议。是的,这是家庭作业。不,我没有标记是因为我被告知作业标记不再常用。
代码:
public class SearchByLyricsWords {
   private static Song[] songs;
   private static TreeMap<String, Song> lyricsTreeMap = new TreeMap<String, Song>();
   private static TreeSet<String> wordsToIgnoreTree = new TreeSet<String>();
   private static File wordsToIgnoreInput = new File("ignore.txt");
   private static String wordsToIgnoreString;
   private static String[] wordsToIgnoreArray;
   private Song[] searchResults;  // holds the results of the search
   private ArrayList<Song> searchList = new ArrayList<Song>();  
public SearchByLyricsWords(SongCollection sc) throws FileNotFoundException {
  // Create a string out of the ignore.txt file
  Scanner scanInputFile = new Scanner(wordsToIgnoreInput);
  String ignoreToken = scanInputFile.next();
  ignoreToken.toLowerCase();
  wordsToIgnoreString = ignoreToken + " ";
  while (scanInputFile.hasNext()) {
     ignoreToken = scanInputFile.next();
     wordsToIgnoreString = wordsToIgnoreString + ignoreToken + " ";
  }
  // Split the string created from ignore.txt 
  wordsToIgnoreArray = wordsToIgnoreString.split("[^a-zA-Z]+");
  // Fill a TreeSet from the wordsToIgnoreArray
  for (int i = 0; i < wordsToIgnoreArray.length; i++) {
     ignoreToken = wordsToIgnoreArray[i];
     wordsToIgnoreTree.add(ignoreToken);
  }
  // Fill TreeMap with lyrics words as the key, Song objects as the value
  songs = sc.getAllSongs();
  for (int j = 0; j < songs.length; j++) {
     Song currentSong = songs[j];
     String lyrics = currentSong.getLyrics();         
     TreeSet<String> lyricsFound = new TreeSet<String>();
     String lyricsToken;
     String[] songLyricsArray;
     songLyricsArray = lyrics.split("[^a-zA-Z]+");
     for (int k = 0; k < songLyricsArray.length; k++) {
        lyricsToken = songLyricsArray[k];
        if (lyricsToken.length() <= 1) {
           continue;
        }
        lyricsFound.add(lyricsToken);
     }
     lyricsFound.removeAll(wordsToIgnoreTree);
     Iterator<String> iterator = lyricsFound.iterator();
     while(iterator.hasNext()) {
        String currentWord = (String)iterator.next();
        lyricsTreeMap.put(currentWord, currentSong);
     }
     //System.out.println(lyricsTreeMap); // testing only
  }
}
public Song[] search(String lyricsWords) {
  lyricsWords = lyricsWords.toLowerCase();
  TreeSet<String> searchTree = new TreeSet<String>();
  String searchToken;
  String[] lyricsWordsSearch = lyricsWords.split("[^a-zA-Z]+");
  for (int l = 0; l < lyricsWordsSearch.length; l++) {
     searchToken = lyricsWordsSearch[l];
     if (searchToken.length() <= 1) {
        continue;            
     }
     searchTree.add(searchToken);
  }
  searchTree.removeAll(wordsToIgnoreTree);
  Iterator<String> searchIterator = searchTree.iterator();
  while(searchIterator.hasNext()) {
     String currentSearchWord = (String)searchIterator.next();
     Collection<Song> lyricsTreeCollection = lyricsTreeMap.values();
     while (lyricsTreeMap.containsKey(currentSearchWord) == true) {
        Iterator collectionIterator = lyricsTreeCollection.iterator();
        while(collectionIterator.hasNext() && collectionIterator.next() == currentSearchWord) {
           Song searchSong = lyricsTreeMap.get(currentSearchWord);
           searchList.add(searchSong);          
        }
     }           
  }
  searchResults = searchList.toArray(new Song[searchList.size()]);
  Arrays.sort(searchResults);
  return searchResults;
}