问题大概是这样:
一个学生可能有多条信息,学生信息为一个map,有姓名,年龄,出生日期,过滤学生信息,先按姓名过滤,相同或为空则过滤年龄,年龄相同或者为空则比对出生日期,比对出生日期选择最小的,要查出信息最全的学生,请问这个逻辑怎么写呢?
map={name='zhangsan',age=18,date='19880101',phone='13329877822',...}
map={name='zhangsan',age=,date='19880101',phone='13329877822',...}
map={name='',age=18,date='19880501',phone='13329877822',...}
map={name='',age=18,date='',phone='13329877822',...} 类似这样,有些信息为空,按顺序过滤,请问怎么写,大神们给点逻辑
3条回答 默认 最新
- ForesterX 2017-05-16 16:59关注
使用集合,使用可hashSet 或者 是 TreeMap
hashMap 的泛型对象的类 可以重写 equals 和 hashCode 方法先过滤 ,如果 要 排序 需要 支持的泛型类的继承Comparator接口 实现里面的
compare方法;具体看你想怎么比,里面就怎么写TreeMap 的构造参数就有按照什么排序的参数,直接使用固定的静态属性当参数,好像是collections类里面的一个静态属性
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报