求助!简单的递归问题

qq_43484130 2021-05-02 11:19:56
1 2 3 4 5 6 7 8 9 10 11 12 从1出发走五步有几种走法 #include<cstdio> #include<cmath> bool charge[3][5] = {false}; int dir[4][2] = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}}; int sum = 0; void dfs(int index, int x, int y) { if (index == 6) { sum++; return; } for (int i = 0; i < 4; i++) { int newx = x + dir[i][0]; int newy = y + dir[i][1]; if ((!charge[newx][newy]) && newx < 4 && newx > 0 && newy < 5 && newy > 0) { charge[newx][newy] = true; dfs(index + 1, newx, newy); charge[newx][newy] = false; } } } int main() { charge[1][1] = true; dfs(1, 1, 1); printf("%d", sum); return 0; } 输出是0 错在哪里??
...全文
151 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
lin5161678 2021-05-05
  • 打赏
  • 举报
回复
能不能重复走已经走过的格子? 1 2 1 2 1 ??
qzjhjxj 2021-05-04
  • 打赏
  • 举报
回复
数组bool charge[3][5]与最上面的数组不符,3*5=15元素,最上面只有12个元素。数组下标:x 0-2,y 0-4; ,代码if ((!charge[newx][newy]) && newx < 4 && newx > 0 && newy < 5 && newy > 0)这里,下标操作越界。

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧