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

 
 
 
日一二三四五六
       
       
       
       
       
       

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

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

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
01月22日漏签0天
c语言吧 关注:801,822贴子:4,375,225
  • 看贴

  • 图片

  • 吧主推荐

  • 视频

  • 游戏

  • 7回复贴,共1页
<<返回c语言吧
>0< 加载中...

求助求助,有没有大佬会做这个题

  • 只看楼主
  • 收藏

  • 回复
  • 114514!!!!
  • 酱油
    4
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
有没有大佬会做这个题,或者跟我解释一下这段代码逻辑就行(搞个思维导图也行)



  • 万恶的bai度W盘
  • 毛蛋
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
看起来是用的数组模拟的广度优先搜索算法。


2026-01-22 16:49:05
广告
不感兴趣
开通SVIP免广告
  • 万恶的bai度W盘
  • 毛蛋
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
可以看BV1r58UzAEPi,这个也是用数组模拟的广搜。


  • GTA小鸡
  • 吧主
    14
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
这是一个最大深度15层的bfs/dfs,每一步操作是一个节点,每个节点有四个不同的方向,再通过记录已走过的节点适当剪枝,避免重复遍历,提升速度。
图里的代码选择bfs实现。


  • 油炸不良人
  • 彩虹面包
    13
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
这个代码能AC,但逻辑上问题挺大换一组数据可能会炸


  • 香菜味包子
  • 团子家族
    10
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
暴力上来说(拿一个3层的小循环举例):
假定 x = 5;
第一次可以变成:
6 , 2,35, 0
第二次可以变成:
7, 3, 42, 0
3, 1,14,0
36, 17, 245, 0
1, 0, 0 ,0
删掉重复的值,得到结果:7 3 42 0 1 14 36 17 245
第三次可以变成:
(懒得算)
这样5可以变化成功的数字就是5 6 2 35 0 7 3 42 1 14 36 17 245 (懒得算)这里的数,检查一下目标值是不是在5 6 2 35 0 7 3 42 1 14 36 17 245 (懒得算)这一串数里就行
这里有个减枝的小寄巧:
对于第一次计算完5的可能值之后,以后出现5这个数就不用再计算了,因为第一次出现的5可能得到的结果的集合一定是第一次以后出现的5可能得到的结果的超集
同理第二次计算完6 , 2,35, 0,之后,以后出现的6 , 2,35, 0也不用在计算了,只用计算每轮出现的新数字就行


  • 那些年_
  • 超能力者
    9
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
把Bfs结果放标志数组里面最后把结果代进去判断应该就行了


登录百度账号

扫二维码下载贴吧客户端

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