很多时候我们都需要对问题结果进行策略性整理方可符合要求;常见排行,有序等等。
网站建设哪家好,找创新互联!专注于网页设计、网站建设、微信开发、成都微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了克山免费建站欢迎大家使用!这边有个问题是试图从一堆数据中找到符合条件的前后 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) { NavigableSetlifePriceTeamSet = 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许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。