我和一些人一起上了个人课,还有名字,年龄范围的细节。
年龄区间为{"0-5“、"6-10”、"11-30“、"31-45”、"46-50“、"50-100”、"100-110"};
我有一个带有name
、ageBand
字符串间隔的Person类,它是参数化构造函数、getter、setter。
class Person {
String name;
String ageBand; //say it is string "0-50" which i pass in constructor while creating a person.
//getters
//setters
}
class TestAgeBand {
public static void main(String args[]) {
ArrayList<Person> person = new ArrayList<Person>();
Person p1 = new Person("Mike1", "0-5");
Person p2 = new Person("Mike2", "6-10");
Person p3 = new Person("Mike3", "11-30");
Person p4 = new Person("Mike4", "31-45");
Person p5 = new Person("Mike5", "50-100");
Person p6 = new Person("Mike6", "46-50");
Person p7 = new Person("Mike7", "100-110");
person.add(p1);
//adding all persons to list.
}
}
下面是我用代码对间隔进行排序的方法。我需要根据增加的间隔对人进行排序。我用树状地图来分类间隔时间。
Map<String, Person> ageBandMap = new TreeMap<String, Person>(){
for(Person p: person) {
ageBandMap.put(p.ageBand, p.name);
}
}
当我打印间隔键集时,我得到
输出:
0-5,100-110,11-30,31-45,46-50,50-100,6-10
我不需要。我需要这样的间隔:
0-5,6-10,11-30,31-45,46-50,50-100,100-110
发布于 2017-09-04 11:41:47
尝试拆分ageBand
字符串并将其转换为Integer
,这样会更容易排序。
person.stream().sorted(Comparator.comparing(element -> Integer.parseInt(element.getAgeBand().split("-")[0])))
.collect(Collectors.toList());
如果不想使用Java 8
,可以使用Collections.sort()
方法。
Collections.sort(person, new Comparator<Person>() {
@Override
public int compare(Person o1, Person o2) {
return Integer.parseInt(o1.getAgeBand().split("-")[0]) - Integer.parseInt(o2.getAgeBand().split("-")[0]);
}
});
发布于 2017-09-04 11:43:46
我们可以尝试在这里变得非常聪明,并将一个自定义比较器传递给TreeMap
,该比较器实际上比较范围。但是请注意,由于您的范围完全不重叠,我们可以使用其各自范围的较低(甚至更高)值来表示Person
,并获得相同的排序效果。因此,我建议如下:
public class Person {
String name;
Integer lower;
Integer upper;
}
SortedSet<Person> set =
new TreeSet<Person>(new Comparator<Person>()
{
public int compare(Person p1, Person p2) {
if (p1 == null && p2 == null) return 0;
if (p1 == null) return -1;
if (p2 == null) return 1;
return p1.getLower().compareTo(p2.getLower());
}
});
发布于 2017-09-04 11:51:05
如果你把键值按你想要的方式打印出来,你可以使用LinkedHashMap
-它记住放置顺序。
https://stackoverflow.com/questions/46036155
复制相似问题