Bomb dropping algorithm

后端 未结 30 873
挽巷
挽巷 2021-01-29 16:55

I have an n x m matrix consisting of non-negative integers. For example:

2 3 4 7 1
1 5 2 6 2
4 3 4 2 1
2 1 2 4 1
3 1 3 4 1
2 1 4 3 2
6 9 1 6 4
         


        
30条回答
  •  悲&欢浪女
    2021-01-29 17:46

    evaluation function, total sum:

    int f (int ** matrix, int width, int height, int x, int y)
    {
        int m[3][3] = { 0 };
    
        m[1][1] = matrix[x][y];
        if (x > 0) m[0][1] = matrix[x-1][y];
        if (x < width-1) m[2][1] = matrix[x+1][y];
    
        if (y > 0)
        {
            m[1][0] = matrix[x][y-1];
            if (x > 0) m[0][0] = matrix[x-1][y-1];
            if (x < width-1) m[2][0] = matrix[x+1][y-1];
        }
    
        if (y < height-1)
        {
            m[1][2] = matrix[x][y+1];
            if (x > 0) m[0][2] = matrix[x-1][y+1];
            if (x < width-1) m[2][2] = matrix[x+1][y+1];
        }
    
        return m[0][0]+m[0][1]+m[0][2]+m[1][0]+m[1][1]+m[1][2]+m[2][0]+m[2][1]+m[2][2];
    }
    

    objective function:

    Point bestState (int ** matrix, int width, int height)
    {
        Point p = new Point(0,0);
        int bestScore = 0;
        int b = 0;
    
        for (int i=0; i bestScore)
                {
                    bestScore = best;
                    p = new Point(i,j);
                }
            }
    
        retunr p;
    }
    

    destroy function:

    void destroy (int ** matrix, int width, int height, Point p)
    {
        int x = p.x;
        int y = p.y;
    
        if(matrix[x][y] > 0) matrix[x][y]--;
        if (x > 0) if(matrix[x-1][y] > 0) matrix[x-1][y]--;
        if (x < width-1) if(matrix[x+1][y] > 0) matrix[x+1][y]--;
    
        if (y > 0)
        {
            if(matrix[x][y-1] > 0) matrix[x][y-1]--;
            if (x > 0) if(matrix[x-1][y-1] > 0) matrix[x-1][y-1]--;
            if (x < width-1) if(matrix[x+1][y-1] > 0) matrix[x+1][y-1]--;
        }
    
        if (y < height-1)
        {
            if(matrix[x][y] > 0) matrix[x][y+1]--;
            if (x > 0) if(matrix[x-1][y+1] > 0) matrix[x-1][y+1]--;
            if (x < width-1) if(matrix[x+1][y+1] > 0) matrix[x+1][y+1]--;
        }
    }
    

    goal function:

    bool isGoal (int ** matrix, int width, int height)
    {
        for (int i=0; i 0)
                    return false;
        return true;
    }
    

    linear maximization function:

    void solve (int ** matrix, int width, int height)
    {
        while (!isGoal(matrix,width,height))
        {
            destroy(matrix,width,height, bestState(matrix,width,height));
        }
    }
    

    This is not optimal, but can be optimized through finding a better evaluation function ..

    .. but thinking about this problem, I was thinking that one of the main issues is getting abandoned figures in the middle of zeroes at some point, so I'd take another approach .. which is dominate minimal values into zero, then try to escape zeroes as possible, which lead to general minimization of minimal existing value(s) or so

提交回复
热议问题