加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

帮助java哈希映射

发布时间:2020-12-15 08:33:53 所属栏目:Java 来源:网络整理
导读:有人可以解释一下下面的代码中发生了什么以及它最终如何以36结束? 谢谢 由Amir Rachum编辑 public class HashMap2009 { public static void main (String[] args) { MapString,Integer myMap2009 = new HashMapString,Integer(); myMap2009.put("one",new I
有人可以解释一下下面的代码中发生了什么以及它最终如何以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个.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读