map.contains( )小问题,在线等

zgycsmb 2012-05-24 03:32:31
下面的代码用于输出字符数组ch中每个字符出现的次数,应该填入的

代码是
public static void main(String[] args) {
char[] ch = { 'a', 'c', 'a', 'b', 'c', 'b' };
HashMap map = new HashMap();
for (int i = 0; i < ch.length; i++) {
< 填入代码 >
}
System.out.println(map);
}

A.if (map.contains(ch[i])) {
map.put(ch[i], map.get(ch[i]) + 1);
} else {
map.put(ch[i], 1);
}

B.if (map.contains(ch[i])) {
map.put(ch[i], (Integer) map.get(ch[i]) + 1);
} else {
map.put(ch[i], 1);
}

C.if (map.containsKey(ch[i])) {
map.put(ch[i], (int) map.get(ch[i]) + 1);
} else {
map.put(ch[i], 1);
}

D.if (map.containsKey(ch[i])) {
map.put(ch[i], (Integer) map.get(ch[i]) + 1);
} else {
map.put(ch[i], 1);
}

正确答案:D
问:为什么其它的三个选项不行呢,thanks
...全文
224 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
ZZZ5512536 2012-05-24
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]

首先HashMap没有contains方法,排除A和B
另外C中map.get(ch[i])返回时Object型无法转成int型,只能转其封装类Integer,
所以选D
[/Quote]

+1
fengchunbo 2012-05-24
  • 打赏
  • 举报
回复
1楼正解
sffx123 2012-05-24
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]
首先HashMap没有contains方法,排除A和B
另外C中map.get(ch[i])返回时Object型无法转成int型,只能转其封装类Integer,
所以选D
[/Quote]+1
菖蒲老先生 2012-05-24
  • 打赏
  • 举报
回复
首先HashMap没有contains方法,排除A和B
另外C中map.get(ch[i])返回时Object型无法转成int型,只能转其封装类Integer,
所以选D

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧