网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
09月14日漏签0天
数据结构吧 关注:104,529贴子:883,654
  • 看贴

  • 图片

  • 吧主推荐

  • 视频

  • 游戏

  • 7回复贴,共1页
<<返回数据结构吧
>0< 加载中...

队列————数细胞

  • 只看楼主
  • 收藏

  • 回复
  • 相当地巴卡
  • 二叉树
    2
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼



  • 相当地巴卡
  • 二叉树
    2
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
各位 大佬 教教我 , 这个数细胞是怎么分的? 队列初学者看了很久这道题 连题目都没读懂+ . +!


2025-09-14 08:45:29
广告
不感兴趣
开通SVIP免广告
  • 小笃笃笃笃
  • 九宫格
    9
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
题目我倒是看懂了,可是为什么需要用队列我不清楚,直接循环遍历判断就可以了,我在思考一下为什么要用队列


  • 小笃笃笃笃
  • 九宫格
    9
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
int SXBJS(int JZ[15][15],int n,int m)
{
int i=1,j=1;
int x,y;
int js=0; //数细胞数目
JD *rear; //声明队列
CSHDL(rear); //初始化队列
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
bj[i][j]=0; //未访问为0
}
}
RD(rear,i,j); //入队
while(DKPD(rear)==1) //队不为空循环
{
CD(rear,x,y); //出队
bj[x][y]=1; //访问为1
if(y+1>m)
{
JZ[x][y+1]=JZ[x][y];
}
if(y-1<=0)
{
JZ[x][y-1]=JZ[x][y];
}
if(x+1>n)
{
JZ[x+1][y]=JZ[x][y];
}
if(x-1<=0)
{
JZ[x-1][y]=JZ[x][y];
}
if(JZ[x][y+1]==JZ[x][y]&&JZ[x+1][y]==JZ[x][y]&&JZ[x][y-1]==JZ[x][y]&&JZ[x-1][y]==JZ[x][y])
{
js++;
}
if(y+1<=m&&bj[x][y+1]==0)
{
RD(rear,x,y+1);
}
if(x+1<=n&&bj[x+1][y]==0)
{
RD(rear,x+1,y);
}
if(y-1>0&&bj[x][y-1]==0)
{
RD(rear,x,y-1);
}
if(x-1>0&&bj[x-1][y]==0)
{
RD(rear,x-1,y);
}
}
return js;
}


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 7回复贴,共1页
<<返回数据结构吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示