【leetcode】面试题 08.10. 颜色填充

 

void dfs(int** image, int imageSize, int colsize, int r, int c, int newColor, int initColor){
    if(r<0 || r>=imageSize || c<0 || c>=colsize || image[r][c]!=initColor || image[r][c]==newColor) return;
    image[r][c]=newColor;
    dfs(image,imageSize,colsize,r-1,c,newColor,initColor);
    dfs(image,imageSize,colsize,r+1,c,newColor,initColor);
    dfs(image,imageSize,colsize,r,c-1,newColor,initColor);
    dfs(image,imageSize,colsize,r,c+1,newColor,initColor);
}
int** floodFill(int** image, int imageSize, int* imageColSize, int sr, int sc, int newColor, int* returnSize, int** returnColumnSizes){
    dfs(image,imageSize,*imageColSize,sr,sc,newColor,image[sr][sc]);
    *returnSize=imageSize;
    (*returnColumnSizes)=imageColSize;
    return image;
}

 

posted @ 2020-11-27 19:50  温暖了寂寞  阅读(139)  评论(0编辑  收藏  举报