poj1656 Counting Black

1656题给定一个100*100初始化颜色为白色的棋盘,输入X、Y左边及长度L画正方形,有两种颜色,白或者黑,在指定的区域涂上色后,输入TEST,同样也给出 X、Y和长度L,求TEST区域内的黑色的小方格个数。

我的想法是设置白色为0,黑色为1,根据指令用二重循环,在二维数组指定区域置成0或1,当输入TEST时,扫描一遍test区域获得黑色小方格数目。

#include<stdio.h>
#include<string.h>

char board[100][100];

void main(){
	char command[10];
	int count,x,y,l,j,m,num;
	int i=0;
	scanf("%d",&count);
	memset(board,'0',sizeof(board));
	while(i<count){
        num=0;
        scanf("%s%d%d%d",command,&x,&y,&l);
        if(0 == strcmp(command,"BLACK")){
            for(j=0;j<l;j++)
                for(m=0;m<l;m++)
                    board[x+j][y+m]='1';
        }
        else if( 0 == strcmp(command,"TEST")){
            for(j=0;j<l;j++)
                for(m=0;m<l;m++){
                    if(board[x+j][y+m]=='1')
                        num++;
                }
            printf("%d\n",num);
        }
        else{
            for(j=0;j<l;j++)
                for (m=0;m<l;m++)
                    board[x+j][y+m]='0';
        }
        i++;
	}
}

wechat
微信扫一扫,订阅我的博客动态^_^