rir*_*roo 5 java sorting collections list point
我有一个点列表,即:List<List<Point>>
.例如:
List<Point> lp;
List<List<Point>> Llp;
Llp.add(lp);
Run Code Online (Sandbox Code Playgroud)
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);
}
Run Code Online (Sandbox Code Playgroud)
这是我到目前为止编写的代码:
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;
}
});
Run Code Online (Sandbox Code Playgroud)
这是我的控制台输出的屏幕截图.我想要对这一点进行排序. http://imageshack.us/scaled/large/515/38zy.png
“我想根据 x 和 y 对外部列表进行排序,假设 x 是 Llp 中 lp 的顺序,y 是 Llp 中每个 lp 的元素的顺序。”
您应该使用自定义比较器。由于我假设 LLP 中的每个列表都具有相同数量的元素,并且每个列表仅适用于不同的 X,因此以下内容应该有效:
//Create the Data
List<List<Point>> Llp = new ArrayList<List<Point>>();
for(int i=0; i< 50; i++)
{
List<Point> lp = new ArrayList<Point>();
for(int j=0; j<50; j++)
lp.add(new Point((int)(Math.random()*1000), i));
Llp.add(lp);
}
// The comparators
Comparator<List<Point>> comparator_rows = new Comparator<List<Point>>() {
@Override
public int compare(List<Point> o1, List<Point> o2) {
int i = o2.get(0).y;
int j = o1.get(0).y;
if (i < j) {
return 1;
} else if (i > j) {
return -1;
} else {
return 0;
}
}
};
Comparator<Point> comparator_columns = new Comparator<Point>() {
@Override
public int compare(Point o1, Point o2) {
int i = o2.x;
int j = o1.x;
if (i < j) {
return 1;
} else if (i > j) {
return -1;
} else {
return 0;
}
}
};
// Sort the rows
Collections.sort(Llp, comparator_rows);
// Sort the columns
for (List<Point> element : Llp)
Collections.sort(element, comparator_columns);
//Print the elements
int rowIndex = 0, columnIndex=0;
for (List<Point> row : Llp)
{
for (Point element : row)
System.out.print("("+element.x+ "," + element.y +")|");
System.out.println();
}
Run Code Online (Sandbox Code Playgroud)
上面的代码获取每行的第一个元素,并提取 X 坐标。然后这个 x 坐标用于对所有行进行排序。
如果您的数据全部混合在一起,您可以使用以下代码,该代码使用 TreeMap 将元素放置在它们应该在的位置。结果是一个锯齿状数组。
//Create the Data
List<List<Point>> Llp = new ArrayList<List<Point>>();
for(int i=0; i< 50; i++)
{
List<Point> lp = new ArrayList<Point>();
for(int j=0; j<50; j++)
lp.add(new Point((int)(Math.random()*1000), (int)(Math.random()*1000)));
Llp.add(lp);
}
//If all data is mixed up we need to filter into new rows based on X using a TreeMap
TreeMap<Integer, TreeMap<Integer,Point>> data = new TreeMap<Integer,TreeMap<Integer,Point>>();
for (List<Point> row : Llp)
{
for (Point element : row)
{
TreeMap<Integer,Point> rowForX;
if(data.containsKey(element.x))
rowForX = data.get(element.x);
else
data.put(element.x, rowForX = new TreeMap<Integer,Point>());
//Create specific row in TreeMap
rowForX.put(element.y,element);
}
}
//Convert Sorted TreeMap(s) to Lists
Llp.clear();
Iterator<Entry<Integer, TreeMap<Integer, Point>>> it = data.entrySet().iterator();
while(it.hasNext())
Llp.add(new ArrayList<Point>(it.next().getValue().values()));
//Print the elements
int rowIndex = 0, columnIndex=0;
for (List<Point> row : Llp)
{
for (Point element : row)
System.out.print("("+element.x+ "," + element.y +")|");
System.out.println();
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
7031 次 |
最近记录: |