能否请您解释一下下面的代码中发生了什么以及它最终如何以36结尾?

谢谢

编辑Amir Rachum的

public class HashMap2009 {
    public static void main (String[] args) {
        Map<String, Integer> myMap2009 =
            new HashMap<String, Integer>();
        myMap2009.put("one", new Integer(1));
        myMap2009.put("three", new Integer(3));
        myMap2009.put("five", new Integer(5));
        myMap2009.put("seven", new Integer(7));
        myMap2009.put("nine", new Integer(9));
        System.out.println(oddOne(myMap2009));
    }
    private static int oddOne(Map<String, Integer> myMap2009) {
        if (myMap2009.isEmpty())
            return 11;
        else {
            Set<String> st = myMap2009.keySet();
            String key = st.iterator().next();
            int num = myMap2009.get(key);
            myMap2009.remove(key);
            return num + oddOne(myMap2009);
        }
    }
}

最佳答案

这是recursion的简单示例,其结果是将映射中的所有键一个接一个地添加,当映射为空时,它将添加另一个11。这总计为36。

08-24 17:43