关于java TreeMap 的问题 一个key 可以有一个或多个values, 如何计算一个key 到底对应了几个value呢?

如题-mapcannotcontainduplicatekeys,thoughofcourseitcancontainduplicatevalues-eachkeymap... 如题
-map cannot contain duplicate keys,though of course it can contain duplicate values
-each key maps to at most one value
-many-to-1 type of object
假如说 以 星座的名字为 KEY , 每个星星看作一个object, 当储存完毕后, 如何计算这个key 到底有多少个星星呢? (不知这样可行吗)
展开
 我来答
JinCeon
推荐于2017-11-25 · TA获得超过695个赞
知道小有建树答主
回答量:350
采纳率:0%
帮助的人:409万
展开全部
一个key 可以有一个或多个values??
谁告诉你的?
你在哪看到的???

=============
你的英文不太好啊
=============
-map cannot contain duplicate keys,though of course it can contain duplicate values
map不能包含重复的key,但是可以包含同样的值。
例如
姓名:张三
姓名:李四
错误。key重复
----------------------------
姓名:张三
备注:张三
正确。value是可以重复的。
===================================
-each key maps to at most one value
每个key最多(at most)对应一个value
===============================
-many-to-1 type of object
多对一类型的对象
如第一条
不能姓名对多个(1对多)
但是可以多对一。比如姓名,备注等的值都为张三
=================================
就拿你的星座和星星举例吧。
水瓶座:星星1
水瓶座:星星2
错误。
-----------------
你只能
星星1:水瓶座
星星2:水瓶座。
懂了吗?
============
另外,欢迎来百度贴吧javase吧来提问
我是操圣
2012-02-25 · TA获得超过1134个赞
知道小有建树答主
回答量:271
采纳率:100%
帮助的人:77.2万
展开全部
TreeMap 和 HashMap 用法大致相同,但实际需求中,我们需要把一些数据进行排序;
以前在项目中,从数据库查询出来的数据放在List中,顺序都还是对的,但放在HashMap中,顺序就完全乱了。

为了处理排序的问题:
1. 对于一些简单的排序,如:数字,英文字母等
TreeMap hm = new TreeMap<String, String>(new Comparator() {
public int compare(Object o1, Object o2) {
//如果有空值,直接返回0
if (o1 == null || o2 == null)
return 0;

return String.valueOf(o1).compareTo(String.valueOf(o2));
}
});
备注:
compareTo(String str) :是String 提供的一个方法,如果参数字符串等于此字符串,
则返回 0 值;如果按字典顺序此字符串小于字符串参数,则返回一个小于 0 的值;
如果按字典顺序此字符串大于字符串参数,则返回一个大于 0 的值。

int compare(T o1,T o2):随第一个参数小于、等于或大于第二个参数而分别返回负整数、
零或正整数。

2.对于处理有中文排序的问题
TreeMap hm = new TreeMap<String, String>(new Comparator() {
public int compare(Object o1, Object o2) {
//如果有空值,直接返回0
if (o1 == null || o2 == null)
return 0;

CollationKey ck1 = collator.getCollationKey(String.valueOf(o1));
CollationKey ck2 = collator.getCollationKey(String.valueOf(o2));
return ck1.compareTo(ck2);
}
});

备注: CollationKey:CollationKey 表示遵守特定 Collator 对象规则的 String。
比较两个CollationKey 将返回它们所表示的 String 的相对顺序。使用 CollationKey
来比较 String 通常比使用 Collator.compare 更快。因此,当必须多次比较 String 时
(例如,对一个 String 列表进行排序),使用 CollationKey 会更高效。

实例:
package ChineseSort;
import java.util.Collection;
import java.util.Iterator;
import java.util.SortedMap;
import java.util.TreeMap;

public class TestSort {
public static void main(String[] args) {
// TODO Auto-generated method stub
CollatorComparator comparator = new CollatorComparator();
TreeMap map = new TreeMap(comparator);
for(int i=0; i<10; i++) {
String s = ""+(int)(Math.random()*1000);
map.put(s,s);
}
map.put("abcd","abcd");
map.put("Abc", "Abc");
map.put("bbb","bbb");
map.put("BBBB", "BBBB");
map.put("北京","北京");
map.put("中国","中国");
map.put("上海", "上海");
map.put("厦门", "厦门");
map.put("香港", "香港");
map.put("碑海", "碑海");
Collection col = map.values();
Iterator it = col.iterator();
while(it.hasNext()) {
System.out.println(it.next());}}}
比较器类:
package ChineseSort;
import java.text.CollationKey;
import java.text.Collator;
import java.util.Comparator;

public class CollatorComparator implements Comparator {
Collator collator = Collator.getInstance();
public int compare(Object element1, Object element2) {
CollationKey key1 = collator.getCollationKey(element1.toString());
CollationKey key2 = collator.getCollationKey(element2.toString());
return key1.compareTo(key2);
}
}
运行该类,运行结果如下:
325
62
653
72
730
757
874
895
909
921
Abc
abcd
bbb
BBBB
碑海
北京
上海
厦门
香港
中国
此时可以看到中文的排序已经完成正常。如果想不让英文区分大小写,则修改CollatorComparator类,找到
element1.toString()
修改为:
element1.toString().toLowerCase()
当然你改成转换成大写的也无所谓了,当然element2.toString()也要同时修改为element2.toString().toLowerCase()。

参考资料: 个人经验

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cxzucc
2012-02-25 · TA获得超过1317个赞
知道小有建树答主
回答量:1735
采纳率:79%
帮助的人:587万
展开全部
你说的values是一个数组吧?通过数组的length属性就可以知道啦。
int length = values.length
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友1a812615e
2012-02-25 · TA获得超过1146个赞
知道小有建树答主
回答量:739
采纳率:66%
帮助的人:420万
展开全部
TreeMap中一个Key只能对应一个value吧?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式