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

carl-zhao
博客专家认证
2014-08-05 02:51:31
一个标签从标签数组中取值的两种方法实现。
一种方法是按标签出次的次数取值按出现。
String[] add = {"北京",“上海”,"四川",“四川”,"北京","四川"};
"地址":"四川";
还有一个方法是按权重进行显示
String[] add = {"北京",“上海”,"四川",“四川”,"北京","四川"};
优先级 上海 > 北京 > 四川
"地址":"上海"(如果上海没有就显示北京,依此类推)。
不知道大家之前遇到到相同的问题没有。希望大家分享一下方法。
...全文
283 19 打赏 收藏 转发到动态 举报
写回复
用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);
		}
该课程由付强老师主讲,系统的、全面的、具体的讲解了java入门的知识。可以使初级的学员入门。Java入门Java的历史、Java的版本、Java的优势、软件行业前景Java开发环境搭建、编写Java入门练习虚拟机的运行机制、Java的平台无关性、虚拟机垃圾回收机制基础语法关键字、标识符、Java数据类型分类、基础数据类型、取值范围变量、常量、三种注释、生成doc文档、运算符、表达式if语句、switch语句、嵌套判断for语句、while语句、do-while语句、嵌套循环类和对象面向过程和面向对象的区别类的构成、访问修饰符、对象的内存分配this关键字、按值传递与按引用传递、对象的初始化顺序高级类特性类的继承、父子类的初始化顺序、单继承性方法的覆盖、重载、super关键字、多态、instanceof关键字、强制类型转换、static关键字、final关键字数组和枚举一维数组的应用及内存分配多维数组的应用及内存分配数组的复制、数组的按引用传递排序算法:冒泡、直接选择、插入选择、希尔、快速、归并、堆排序Arrays工具类的应用枚举类型的应用常见类的使用Object类的底层及应用、Objects类String类的底层及应用、正则表达式StringBuffer和StringBuilder的底层及应用Math类的应用、包装类的应用日期类的应用:Date、DateFormat、Calendar、LocalDateTime、Instant、LocalDate、MonthDay、ZonedDateTime、YearMonth、新旧日期转换BigInteger和BingDecimal、DecimalFormatSystem类、Scanner类抽象类和接口抽象类的规则及应用接口的规则及应用默认方法、静态方法、函数式接口、Lambda表达式异常异常的定义异常的处理:抓(try-catch-finally)、抛(throws)异常的分类、自定义异常的应用、throw关键字集合框架集合框架结构:接口、实现类Collection接口的方法、Set接口的方法、List接口的方法、Map接口的方法Array、Linked、Hash、Tree底层实现原理泛型的作用、Collections工具类、历史集合类I/O流Path类的原理及应用、Files类的原理及应用文件字节流FileInputStream的原理及应用对象类、缓冲流、数据流的原理及应用字符流的原理及应用多线程进程与线程的概念、查看线程对象Java内存模型线程的创建与启动:扩展Thread类、实现Runnable接口、实现Callable接口、线程池线程状态的转换:新建、就绪、运行、阻塞、死亡线程的调度:sleep、yield、join、interrupt、wait后台线程、定时任务线程的并发与同步、同步锁、同步块、线程安全的类Lock接口、CAS、volatile修饰符内部类成员内部类、本地内部类的应用匿名内部类的原理及引用、Lambda表达式设计模式基础设计模式概念、框架概念7大设计原则:开闭原则、依赖倒置原则、单一职责原则、接口隔离原则、迪米特原则、里氏替换原则、合成复用原则单例模式、工厂模式、模板模式、代理模式、装饰模式、适配器模式、外观模式、策略模式、观察者模式、命令模式、备忘录模式、观察者模式反射反射包Class类的使用反射获取类属性、方法、构造器通过反射创建类对象/通过反射调用方法反射的应用

62,614

社区成员

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

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