有效地列出网格中每个唯一的点对

时间:2014-02-27 21:22:37

标签: algorithm grid iteration

看似一个简单的问题,我正在寻找一种算法来列出网格中与原点不共线的每一对唯一点。诀窍是以某种方式避免所有不同的对称性和巧合。这就是我到目前为止所做的:

for( int x1 = 0; x1 <= s; x1++ ){
    for( int y1 = 0; y1 <= s; y1++ ){
        if( x1 == 0 && y1 == 0 ) continue; // P1 is coincident with origin
        for( int x2 = x1; x2 <= s; x2++ ){
            for( int y2 = 0; y2 <= s; y2++ ){
                if( x1 == x2 && y2 >= y1 ) continue;
                if( x1 * y2 == x2 * y1 ) continue; // points are collinear with origin
                // this is a valid point
            }
        }
    }
}

1 个答案:

答案 0 :(得分:1)

枚举所有唯一对(通过在网格点上定义顺序)并忽略与原点对齐的那些对。

def Pair(X0, Y0, X1, Y1):
    if X0 * Y1 != X1 * Y0:
        # Non collinear with the origin
        Accept(X0, Y0, X1, Y1)

# Enumerate all (X0, Y0)
for X0 in range(NX):
    for Y0 in range(NY):
        # Enumerate all (X1, Y1) > (X0, Y0) in the lexicographical sense

        # 1) X1 == X0, Y1 > Y0
        X1= X0
        for Y1 in range(Y0 + 1, NY):
            Pair(X0, Y0, X1, Y1)

        # 2) X1 > X0
        for X1 in range(X0 + 1, NX):
            for Y1 in range(NY):
                Pair(X0, Y0, X1, Y1)

或者,更好:

# Enumerate all (X0, Y0)
for X0 in range(NX):
    for Y0 in range(NY):
        # Enumerate all (X1, Y1) > (X0, Y0) in the lexicographical sense
        for X1 in range(X0, NX):
            for Y1 in range(0 if X1 > X0 else Y0 + 1, NY):
                if X0 * Y1 != X1 * Y0:
                    # Non collinear with the origin
                    Accept(X0, Y0, X1, Y1)
相关问题