我有一个点列表列表,即:List<List<Point>>
。例如:
List<Point> lp;
List<List<Point>> Llp;
Llp.add(lp);
lp
将是我矩阵的第一行(x = 0)。Llp
是整个矩阵。
我想根据每个点的 x 和 y 对列表进行升序排序。我只设法对内部列表进行了排序,而不是对整个列表进行了排序。任何人都可以帮助我吗?谢谢你。这是我根据 y 对内部列表(即矩阵的第一行)进行排序的代码。
private void ord_horiz (List<Point> tab)
{
boolean ordered_horiz = false;
int size = tab.size();
while(!ordered_horiz)
{
ordered_horiz = true;
for(int i=0 ; i < size-1 ; i++)
{
if(tab.get(i).y > tab.get(i+1).y)
{
swap(tab, i, i+1);
ordered_horiz = false;
}
}
size--;
}
}
private void swap(List<Point> tab, int ind1, int ind2)
{
Point c;
c = tab.get(ind1);
tab.set(ind1, tab.get(ind2));
tab.set(ind2, c);
}
这是我到目前为止编写的代码:
Collections.sort(tab,new Comparator<List<Point>>(){
@Override
public int compare(List<Point> o1, List<Point> o2) {
if(o1 != null && o2 !=null)
{
Point var1 = o1.get(0);
int var1_x = var1.x;
int var1_y = var1.y;
Point var2 = o2.get(0);
int var2_x = var2.x;
int var2_y = var2.y;
Integer.compare(var1_x, var2_x);
Integer.compare(var1_y, var2_y);
return /* What shall I return ? */;
}
return 0;
}
});
这是我的控制台输出的屏幕截图。我希望对这一点进行排序。 http://imageshack.us/scaled/large/515/38zy.png