java sort自定义比较的用法

先定义类
public class sortContours implements Comparator<MatOfPoint>{

		public int compare(MatOfPoint p1, MatOfPoint p2) {
			return p1.toArray().length - (p2.toArray().length);
		}
	}
再调用<pre name="code" class="java">MatOfPoint MP[] = new MatOfPoint[contours.toArray().length];
MP = contours.toArray(MP);
Arrays.sort(MP, new sortContours());

另外一种方法是用Collections,见代码:

ArrayList<ArrayList<Double>> Shoulder_FL = new ArrayList<ArrayList<Double>>();
<pre name="code" class="java">Shoulder_FL需赋值...

 
Comparator<ArrayList<Double>> comparator = new Comparator<ArrayList<Double>>() {
	        public int compare(ArrayList<Double> c1, ArrayList<Double> c2) {
	            return (int)(c2.get(181) - c1.get(181)); // use your logic
	        }
	    };

	    Collections.sort(Shoulder_FL, comparator);
但是第二种方法有时会报出comparison method violates its general contract!的错误。原因见:http://dertompson.com/2012/11/23/sort-algorithm-changes-in-java-7/
所以修改上述<span style="font-family: Arial, Helvetica, sans-serif;">Comparator为:</span>
<span style="font-family: Arial, Helvetica, sans-serif;"></span><p class="p1">Comparator<ArrayList<Double>> <span class="s1">comparator</span> = <span class="s2">new</span> Comparator<ArrayList<Double>>() {</p><p class="p1"><span>	</span>        <span class="s2">public</span> <span class="s2">int</span> compare(ArrayList<Double> <span class="s1">c1</span>, ArrayList<Double> <span class="s1">c2</span>) {</p><p class="p1"><span>	</span>        <span>	</span><span class="s2">if</span> (<span class="s1">c2</span>.get(181) == <span class="s1">c1</span>.get(181)) {</p><p class="p1"><span>	</span>        <span>	</span>    <span class="s2">return</span> 0;//0即为不排序, 1为降序</p><p class="p1"><span>	</span>        <span>	</span>}</p><p class="p1"><span>	</span>        <span>	</span><span class="s2">else</span> <span class="s2">if</span> (<span class="s1">c2</span>.get(181) < <span class="s1">c1</span>.get(181)) {</p><p class="p1"><span>	</span>        <span>	</span>    <span class="s2">return</span> -1;//升序排序</p><p class="p1"><span>	</span>        <span>	</span>}</p><p class="p1"><span>	</span>        <span>	</span><span class="s2">else</span> {</p><p class="p1"><span>	</span>        <span>	</span>    <span class="s2">return</span> 1;//降序排序</p><p class="p1"><span>	</span>        <span>	</span>}</p><p class="p1"><span>	</span>        }</p><p class="p1"><span>	</span>    };</p>


 
参考文章:http://www.tutorialspoint.com/java/util/arraylist_toarray.htm
http://fuxueliang.com/tech/2013/05/26/java-sorting-comparator-vs-comparable-tutorial/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中,可以通过实现 `Comparator` 接口来自定义排序规则。 `Comparator` 接口有一个 `compare()` 方法,可以在其中编写自定义比较逻辑。 假设有一个 `Person` 类,其中包含 `name` 和 `age` 两个字段,现在要按照年龄从小到大排序,如果年龄相同,则按照姓名字典序排序。代码如下: ```java import java.util.Comparator; public class Person { private String name; private int age; // 构造方法和 getter/setter 略 // 自定义比较器 public static Comparator<Person> ageNameComparator = new Comparator<Person>() { @Override public int compare(Person p1, Person p2) { if (p1.getAge() < p2.getAge()) { return -1; } else if (p1.getAge() > p2.getAge()) { return 1; } else { return p1.getName().compareTo(p2.getName()); } } }; } ``` 在上面的代码中,我们定义了一个 `ageNameComparator` 比较器,它可以按照年龄从小到大排序,如果年龄相同,则按照姓名字典序排序。在 `compare()` 方法中,我们首先比较两个 `Person` 对象的年龄,如果年龄不同,就直接返回比较结果;如果年龄相同,就比较两个 `Person` 对象的姓名。 使用自定义比较器进行排序,可以通过调用 `Collections.sort()` 方法,并传入自定义比较器作为参数,示例代码如下: ```java import java.util.ArrayList; import java.util.Collections; import java.util.List; public class Main { public static void main(String[] args) { List<Person> personList = new ArrayList<>(); // 添加 Person 对象到 personList 中,省略... // 使用自定义比较器进行排序 Collections.sort(personList, Person.ageNameComparator); // 输出排序结果 for (Person person : personList) { System.out.println(person.getName() + ", " + person.getAge()); } } } ``` 在上面的代码中,我们将 `Person` 对象添加到 `personList` 中,然后使用 `Collections.sort()` 方法对其进行排序,排序规则是按照 `Person.ageNameComparator` 自定义比较器进行排序。最后,打印排序结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值