【算法】腾讯模拟题:画家小Q

问题形貌

画家小Q又最先他的艺术创作。小Q拿出了一块有NxM像素格的画板, 画板初始状况是空缺的,用’X’示意。
小Q有他奇特的绘画技能,每次小Q会挑选一条斜线, 假如斜线的方向形如’/’,即斜率为1,小Q会挑选这条斜线中的一段格子,都涂画为蓝色,用’B’示意;假如对角线的方向形如”,即斜率为-1,小Q会挑选这条斜线中的一段格子,都涂画为黄色,用’Y’示意。
假如一个格子既被蓝色涂画过又被黄色涂画过,那末这个格子就会变成绿色,用’G’示意。
小Q已经有想画出的作品的模样, 请你帮他盘算一下他起码须要多少次操纵完成这幅画。

输入形貌

每一个输入包括一个测试用例。
每一个测试用例的第一行包括两个正整数N和M(1 <= N, M <= 50), 示意画板的长宽。
接下来的N行包括N个长度为M的字符串, 个中包括字符'B','Y','G','X',离别示意蓝色,黄色,绿色,空缺。全部示意小Q要完成的作品。

输出形貌

输出一个正整数, 示意小Q起码须要多少次操纵完成绘画。

示例1

输入

4 4
YXXB
XYGX
XBYY
BXXY

输出

3

申明

XXXX
XXXX
XXXX
XXXX
->
YXXX
XYXX
XXYX
XXXY
->
YXXB
XYBX
XBYX
BXXY
->
YXXB
XYGX
XBYY
BXXY

问题泉源及本身的思绪

链接

https://www.nowcoder.com/ques…

泉源

牛客网

思绪

从(0,0)位置最先遍历

假如遍历到(i,j)位置为B——>则继承向左下方(i+1,j-1)和右上方(i-1,j+1)
遍用时,碰到将B置为X,碰到G置为(消弭B)置为Y
count++;
假如遍历到(i,j)位置为Y——>则继承向左上方(i-1,j-1)和右下方(i+1,j+1)
遍用时,碰到将Y置为X,碰到G置为(消弭Y)置为B
count++;
假如遍历到(i,j)位置为G——>则离别实行1,2

相干代码

Java完成

import java.util.Scanner; 
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String tem = scanner.nextLine();
        int n = Integer.valueOf(tem.split(" ")[0]);
        int m = Integer.valueOf(tem.split(" ")[1]);
        char color[][] = new char[n][m];
        for (int i = 0; i < n; i++) {
            tem = scanner.nextLine();
            for (int j = 0; j < tem.length(); j++) {
                color[i][j] = tem.charAt(j);
            }
        }
 
        getMinStep(n, m, color);
 
        scanner.close();
 
    }
 
    private static void getMinStep(int n, int m, char color[][]) {
 
        int step = 0;
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                if (color[i][j] == 'Y') {
                    dray(i, j, n, m, color); 
                    step++;
                } else if (color[i][j] == 'B') {
                    drab(i, j, n, m, color); 
                    step++;
                } else if (color[i][j] == 'G') {
                    dray(i, j, n, m, color); 
                    step++;
                    drab(i, j, n, m, color); 
                    step++;
                }
            }
        }
 
        System.out.println(step);
    }
    private static void dray(int x, int y, int n, int m, char color[][]) {
       
        if (x >= 0 && x < n && y >= 0 && y < m && (color[x][y] == 'Y' || color[x][y] == 'G')) {
            if (color[x][y] == 'G') {
                color[x][y] = 'B'; 
            } else {
                color[x][y] = 'X';
            }
 
            dray(x - 1, y - 1, n, m, color);
            dray(x + 1, y + 1, n, m, color);
 
        }
 
    }
 
    private static void drab(int x, int y, int n, int m, char color[][]) {
   
        if (x >= 0 && x < n && y >= 0 && y < m && (color[x][y] == 'B' || color[x][y] == 'G')) {
            if (color[x][y] == 'G') {
                color[x][y] = 'Y'; 
            } else {
                color[x][y] = 'X'; 
            }
 
            drab(x + 1, y - 1, n, m, color);
            drab(x - 1, y + 1, n, m, color);
 
        }
    }
 
}

JavaScript完成

while(line=readline()){
    let lines = line.split(" ");
    let n = parseInt(lines[0]);
    let m = parseInt(lines[1]);
    let arr = new Array();
    for(let i = 0; i < n; i++){
        let line2 = readline();
        arr[i] = new Array();
        for(let j = 0; j < m; j++){
            arr[i][j] = line2[j];
            //print(arr[i][j]);
        }
    }
    let step = 0;
    for(let i = 0; i < n; i++){
        for(let j = 0; j < m; j++){
            //print("---------## 访问点(" + i +" , "+ j + " ): " +arr[i][j]);
            if(arr[i][j] == 'Y'){
                draw_y(arr, i, j, n, m);
                step++;
            }else if(arr[i][j] == 'B'){
                draw_b(arr, i, j, n, m);
                step++;
            }else if(arr[i][j] == 'G'){
                draw_y(arr, i, j, n, m);
                step++;
                draw_b(arr, i, j, n, m);
                step++
            }
        }
    }
    print(step);
}
function draw_y(arr,x,y,n,m){
    //print("draw_y:");
    //print(x,y,n,m);
    if(x >= 0 && x < n && y >=0 && y < m && (arr[x][y] == 'Y' || arr[x][y] == 'G')){
        if(arr[x][y] == 'Y'){
            arr[x][y] = 'X';
        }else{
            arr[x][y] = 'B';
        }
        //print("("+x+","+y+")"+"左上角:");
        draw_y(arr, x-1, y-1, n, m);
        
        //print("("+x+","+y+")"+"右下角:");
        draw_y(arr, x+1, y+1, n, m);
    }
}
function draw_b(arr,i,j,n,m){
    //print("draw_b:");
    //print(i,j,n,m);
    if(i >= 0 && i < n && j >=0 && j < m && (arr[i][j] == 'G' || arr[i][j] == 'B')){
        if(arr[i][j] == 'B'){
            arr[i][j] = 'X';
        }else{
            arr[i][j] = 'Y';
        }
        
        //print("("+i+","+j+")"+"左下角:");
        draw_b(arr, i-1, j+1, n, m);
        
        //print("("+i+","+j+")"+"右上角:");
        draw_b(arr, i+1,j-1,n,m);
    }
}

总结

一道题调试了一个礼拜,厥后被人提示,原来是把=写成了==.一向都没发明,修正以后就可以通过了QAQ

    原文作者:afra
    原文地址: https://segmentfault.com/a/1190000016251177
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞