我想根据Julia中的每个长度对一个数组进行排序,该数组的因子为((x1,y1(,(x2,y2((,表示一条线的两条边
由于Python和Julia之间的细微差别,我不能写作
在Python中,行的排序如下所示;
lines = [ ((l[0][0], l[0][1]), (l[0][2], l[0][3])) for l in lines ]
lines.sort(key = lambda l: -sqrt((l[0][0]-l[1][0])**2+(l[0][1]-l[1][1])**2))
如何在Julia中编写相同的过程?
你似乎想要这个:
lines = [((a,b), (c,d)) for (a,b,c,d) in lines]
或者这个
lines = [((a,b), (c,d)) for (a,b,c,d) in eachrow(lines)]
(我需要一个输入lines
和预期输出的例子来确定(
为了对其进行排序,只需使用by
kwarg:
sort!(lines, by=(((a,b), (c,d)),) -> -sqrt((a-c)^2+(b-d)^2))
或
sort!(lines, by=x -> -sqrt((x[1][1]-x[2][1])^2+(x[2][1]-x[2][2])^2))