解题思路:





注意事项:





参考代码:

#include<stdio.h>

int k(int cs,int a[8][8],int n,int bex,int bey)

{

int i,j,ik,jk,zl=0,h,f;

int b[8][8];


for(h=0;h<n;h++)

  for(f=0;f<n;f++)

   b[h][f]=a[h][f];


for(i=bex;i<n;i++)

{

if(i==bex){ j=bey; }

else{j=0;}

    for(;j<n;j++)

{


       if(b[i][j]==1)

  {

           if(cs==1)  { zl++;}

           else{

            b[i][j]=2;

            ik=i-1;

                   while(ik>=0 && b[ik][j]!=0)

  { b[ik][j]=2; ik--; }

                   ik=i+1;

                   while(ik<n && b[ik][j]!=0)

  { b[ik][j]=2; ik++;}

                   jk=j-1;

                   while(jk>=0 && b[i][jk]!=0)

  {b[i][jk]=2;jk--;}

                   jk=j+1;

                   while(jk<n && b[i][jk]!=0)

  {b[i][jk]=2;jk++;}    

                 zl+=k(cs-1,b,n,i,j+1);

                          for(h=0;h<n;h++)

                          for(f=0;f<n;f++)

                          b[h][f]=a[h][f];

  }


  }


}

}


return zl;

}

void main()

{

int a[8][8];

int n,i,j,zl=1,cs=1;

scanf("%d",&n);

for(i=0;i<n;i++)

for(j=0;j<n;j++)

scanf("%d",&a[i][j]);


while(zl){

zl=0;

if(cs==1)

{

for(i=0;i<n;i++)

for(j=0;j<n;j++)

zl+=a[i][j];

}

else{

zl+=k(cs,a,n,0,0);

}

if(zl!=0)

printf("%d\n",zl);

cs=cs+1;

}

}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论