很多时候我们都需要对问题结果进行策略性整理方可符合要求;常见排行,有序等等。

这边有个问题是试图从一堆数据中找到符合条件的前后 10 个数据, 条件是与指定的值接近的前后 10 个。设想吧
如果这一堆数据是有序的就好了。
如果上面的满足了, 能直接取道我自己元素的位置就好了。这样的话。 index++ 和 index-- 分别取 10 次就 ok 了。
于是,决定用 NavigableSet
import java.util.Collections;
import java.util.Comparator;
import java.util.LinkedList;
import java.util.List;
import java.util.NavigableSet;
import java.util.TreeSet;
import org.apache.commons.lang.ArrayUtils;
public class SortedSetTest {
public static void main(String[] args) {
NavigableSet lifePriceTeamSet = new TreeSet();
lifePriceTeamSet.add(new Temp(3, "a"));
lifePriceTeamSet.add(new Temp(1, "b"));
lifePriceTeamSet.add(new Temp(5, "c"));
lifePriceTeamSet.add(new Temp(4, "d"));
lifePriceTeamSet.add(new Temp(9, "c"));
lifePriceTeamSet.add(new Temp(2, "d"));
Temp temp = lifePriceTeamSet.higher(new Temp(6, "g"));
...
System.out.println();
temp = lifePriceTeamSet.lower(new Temp(6, "g"));
...
}
static class Temp implements Comparable {
private int id;
private String name;
public Temp(int id, String name){
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Temp [id=" + id + ", name=" + name + "]";
}
@Override
public int compareTo(Temp o) {
if (this.getId() > o.getId())
{
return -1;
}
else if (this.getId() == o.getId())
{
return 0;
}
else
{
return 1;
}
}
}
} 另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。