一个标签从标签数组中取值方法实现

carl-zhao
博客专家认证
2014-08-05 02:51:31
一个标签从标签数组中取值的两种方法实现。
一种方法是按标签出次的次数取值按出现。
String[] add = {"北京",“上海”,"四川",“四川”,"北京","四川"};
"地址":"四川";
还有一个方法是按权重进行显示
String[] add = {"北京",“上海”,"四川",“四川”,"北京","四川"};
优先级 上海 > 北京 > 四川
"地址":"上海"(如果上海没有就显示北京,依此类推)。
不知道大家之前遇到到相同的问题没有。希望大家分享一下方法。
...全文
290 19 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
19 条回复
切换为时间正序
请发表友善的回复…
发表回复
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 17 楼 rui888 的回复:
你String 放到map 里面 根据优先级作为key 取数据。
String[] add = { "北京", "上海", "四川", "四川", "北京", "四川", "上海", "上海", "上海","上海", "上海", "上海" };
		Map<String,String> m = new  HashMap<String,String>();
		for (String o : add) {
			m.put(o, o);
		}
		//根据优先级 
		m.get(key);
太谢谢你了。
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
你String 放到map 里面 根据优先级作为key 取数据。
String[] add = { "北京", "上海", "四川", "四川", "北京", "四川", "上海", "上海", "上海","上海", "上海", "上海" };
		Map<String,String> m = new  HashMap<String,String>();
		for (String o : add) {
			m.put(o, o);
		}
		//根据优先级 
		m.get(key);
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 15 楼 rui888 的回复:
String[] add = {"北京",“上海”,"四川",“四川”,"北京","四川"};
引用
这个 重庆 > 上海 > 北京 > 四川 是先就知道了是吧
然后直接索引?[code=java]String[] add = { "北京", "上海", "四川", "四川", "北京", "四川", "上海", "上海", "上海", "上海", "上海", "上海" }; List<String> list = Arrays.asList(add);
优先级肯定是先知道的。传进来的String数组是不定的。这个逻辑怎么弄呢?
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
String[] add = {"北京",“上海”,"四川",“四川”,"北京","四川"};
引用
这个 重庆 > 上海 > 北京 > 四川 是先就知道了是吧
然后直接索引?[code=java]String[] add = { "北京", "上海", "四川", "四川", "北京", "四川", "上海", "上海", "上海", "上海", "上海", "上海" }; List<String> list = Arrays.asList(add);
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 13 楼 rui888 的回复:
没明白啊。 这个 优先级 重庆 > 上海 > 北京 > 四川 哪里来的 是不是有这个直接去string数组里面找?
是从string数组里面找。就是说数组中不管数组中有什么值。只要有重庆就显示重庆,如果没有重庆就打有没有上海。有上海就显示上海。依次类推。
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
没明白啊。 这个 优先级 重庆 > 上海 > 北京 > 四川 哪里来的 是不是有这个直接去string数组里面找?
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 10 楼 rui888 的回复:
权重和次数不是同一思路? 权重什么意思啊。怎么取?
权重就是优先级。
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 10 楼 rui888 的回复:
权重和次数不是同一思路? 权重什么意思啊。怎么取?
还有一个方法是按权重进行显示 String[] add = {"北京",“上海”,"四川",“四川”,"北京","四川","重庆"}; 优先级 重庆 > 上海 > 北京 > 四川 "地址":"重庆"(如果String数组没有重庆就显示上海,依此类推)。
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
权重和次数不是同一思路? 权重什么意思啊。怎么取?
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
按照字数最多解决了。按照权重方式返回怎么弄呢?
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
String[] add = { "北京", "上海", "四川", "四川", "北京", "四川", "上海", "上海", "上海",
				"上海", "上海", "上海" };
		Arrays.sort(add);

		Map<String, Integer> m = new TreeMap<String, Integer>();
		for (String d : add) {
			if (m.get(d) != null) {
				m.put(d, m.get(d) + 1);
			} else {
				m.put(d, 1);
			}
		}

		List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(m.entrySet());
		Collections.sort(list, new Comparator<Map.Entry<String, Integer>>() {
			public int compare(Map.Entry<String, Integer> o1,
					Map.Entry<String, Integer> o2) {
				return (o1.getValue() - o2.getValue());
			}
		});

		for (Map.Entry<String, Integer> o : list) {
			System.out.println(o);
		}
whos2002110 2014-08-05
  • 打赏
  • 举报
回复
不管哪种方法都需要两个条件, 当多个地址出现次数相同时,还是要有个权重来经行二次筛选。 权重的设计不应该是一个城市一个权重, 不然100个地址100个权重么? 建议你一个权重可以包含多个地址: 比如1级对应北、上、广、深, 2级对应四川、浙江、江苏等。 如果先按出现次数,就用Map统计下add[] 里面每个地址出现的次数,最大的为结果,如果有相同的再取权重,如果权重也相同那你就随意吧,从中选一个。 如果按权重,那你从高到低依次查询, 同一权重出现多个再按出现次数。 实现的话可能稍微有点绕。 可以使用Map<Integer, List<String>> weight; 类似这样来保存地址的权重信息。
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
Arrays.sort 是有问题的。
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 4 楼 rui888 的回复:
就是取出那个 单词最多,然后排序好, 那怎么做啊。不是这个意思?
你这个并不是按单词个数排序。而是按照String排序。我把String[] add = { "北京", "上海", "四川", "四川", "北京", "四川" };变成String[] add = { "北京", "上海", "四川", "四川", "北京", "四川", "上海", "上海" , "上海", "上海" , "上海", "上海" };排序结果一样。试试。
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
就是取出那个 单词最多,然后排序好, 那怎么做啊。不是这个意思?
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 1 楼 rui888 的回复:
String[] add = { "北京", "上海", "四川", "四川", "北京", "四川" };
		Arrays.sort(add);
		Map<String, String> m = new TreeMap<String, String>();
		for (String d : add) {
			m.put(d, d);
		}
		for (String key : m.keySet()) {
			System.out.println(key);
		}
我发现你这个代码是把字符串进行一次排序,然后去重。然后就是把排序去重的字符串依次读取出来。不切题呀。
carl-zhao 2014-08-05
  • 打赏
  • 举报
回复
引用 1 楼 rui888 的回复:
String[] add = { "北京", "上海", "四川", "四川", "北京", "四川" };
		Arrays.sort(add);
		Map<String, String> m = new TreeMap<String, String>();
		for (String d : add) {
			m.put(d, d);
		}
		for (String key : m.keySet()) {
			System.out.println(key);
		}
这个是按照次数排序的吗?
tony4geek 2014-08-05
  • 打赏
  • 举报
回复
String[] add = { "北京", "上海", "四川", "四川", "北京", "四川" };
		Arrays.sort(add);
		Map<String, String> m = new TreeMap<String, String>();
		for (String d : add) {
			m.put(d, d);
		}
		for (String key : m.keySet()) {
			System.out.println(key);
		}

62,635

社区成员

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

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