Why is this causing a runtime error? (finding word count of a string using HashMap)

157 views Asked by At
import java.util.HashMap;
import java.util.Iterator;

class L6ex1pt2 {
    String line = "When I was there, it was there"; //works for Strings with all unique words 
                                                    //but not for Strings with repeated words (like this)

    public static void main(String[] args) {
        L6ex1pt2 test = new L6ex1pt2();
        HashMap<String, Integer> hash = new HashMap<String, Integer>();
        hash = test.countWords(test.line);

    }

    public String[] words(String s) {
        String[] words = s.split("\\s+");           
        return words;
    }

    public HashMap<String, Integer> countWords(String s) {
        HashMap<String, Integer> wordCount = new HashMap<String, Integer>();
        String[] werds = words(s);
        for (String w: werds) {
            if (wordCount.containsKey(w)) {
                wordCount.put(w, wordCount.get(s)+1);
            } else {
                wordCount.put(w, 1);                
            }
        }
        return wordCount;
    }

}

Throws this exception:

Exception in thread "main" java.lang.NullPointerException at L6ex1pt2.countWords(L6ex1pt2.java:24) at L6ex1pt2.main(L6ex1pt2.java:10)

3

There are 3 answers

0
Julin Alex On BEST ANSWER

Line 25

wordCount.put(w, wordCount.get(s)+1);

should be

wordCount.put(w, wordCount.get(w)+1);

Since s contains the whole string and not the word you expect for the hashmap key.

0
KnockingHeads On

In your line number 24, you have wrongly written: wordCount.put(w, wordCount.get(s)+1);

It should be:

wordCount.put(w, wordCount.get(w)+1);

0
Som On

Replace get(s)+1 with get(w)+1

Full code :

import java.util.HashMap;
import java.util.Iterator;

public class Main {
    
    String line = "When I was there it was there"; 
    
    public static void main(String[] args) {
        
        Main test = new Main();
        HashMap<String, Integer> hash = new HashMap<String, Integer>();
        hash = test.countWords(test.line);
        System.out.println(hash);
    }

    public HashMap<String, Integer> countWords(String s) {
        HashMap<String, Integer> wordCount = new HashMap<String, Integer>();
        String[] wordsArr = words(s);
        for (String w: wordsArr) {
            if (wordCount.containsKey(w)) {
                wordCount.put(w, wordCount.get(w)+1);
            } else {
                wordCount.put(w, 1);                
            }
        }
        return wordCount;
    }
    
    public String[] words(String s) {
        String[] words = s.split("\\s+");           
        return words;
    }
}

Output :

{When=1, there=2, was=2, I=1, it=1}