鱼C论坛

 找回密码
 立即注册
查看: 2811|回复: 11

[已解决]马走日 问题

[复制链接]
发表于 2018-9-9 21:15:10 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
m =[[0, 0, 1, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 1, 0, 0, 0],
[0, 0, 0, 0, 1, 0, 1, 0, 0, 0],
[0, 1, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 1, 0, 1, 1, 0, 0, 0],
[0, 0, 1, 0, 0, 0, 0, 0, 0, 0],
[1, 0, 0, 0, 0, 0, 0, 0, 1, 1],
[0, 0, 0, 1, 0, 0, 0, 0, 1, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 1, 0]]

按照马走日的规则(2*3的对角线),只能跳数字1,同一个1可以跳多次,
问,这个二维数组需要几匹马,才可以跳完数组里所有的一,
答案是七次,
图片里面不同的颜色或者图标的代表一匹马走过的1.
最佳答案
2018-9-9 21:48:24
用递归比较容易完成。
  1. m =[[0, 0, 1, 0, 0, 0, 0, 0, 0, 0],
  2. [0, 0, 0, 0, 0, 0, 1, 0, 0, 0],
  3. [0, 0, 0, 0, 1, 0, 1, 0, 0, 0],
  4. [0, 1, 0, 0, 0, 0, 0, 0, 0, 0],
  5. [0, 0, 0, 1, 0, 1, 1, 0, 0, 0],
  6. [0, 0, 1, 0, 0, 0, 0, 0, 0, 0],
  7. [1, 0, 0, 0, 0, 0, 0, 0, 1, 1],
  8. [0, 0, 0, 1, 0, 0, 0, 0, 1, 0],
  9. [0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
  10. [0, 0, 0, 0, 0, 0, 0, 0, 1, 0]]
  11. col = len(m)
  12. row = len(m[0])
  13. count = 0
  14. def move(i, j):
  15.     try:
  16.         if i >= 0 and j >= 0 and m[i][j] == 1:
  17.             m[i][j] = 2
  18.             move(i - 2, j + 1)
  19.             move(i - 1, j + 2)
  20.             move(i + 1, j + 2)
  21.             move(i + 2, j + 1)
  22.             move(i + 2, j - 1)
  23.             move(i + 1, j - 2)
  24.             move(i - 1, j - 2)
  25.             move(i - 2, j - 1)
  26.     except IndexError:
  27.         pass
  28.         
  29.             
  30.         
  31. for i in range(col):
  32.     for j in range(row):
  33.         if m[i][j] == 1:
  34.             count += 1
  35.             move(i, j)
  36. print(count)
复制代码
WechatIMG3.jpeg
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-9-9 21:16:22 | 显示全部楼层
求大神帮助
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-9-9 21:20:23 | 显示全部楼层
求python 代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-9 21:29:54 | 显示全部楼层
楼主 求一个VIP账号 真的很需要学习C语言的课程 我正在学习C语言
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-9 21:48:24 | 显示全部楼层    本楼为最佳答案   
用递归比较容易完成。
  1. m =[[0, 0, 1, 0, 0, 0, 0, 0, 0, 0],
  2. [0, 0, 0, 0, 0, 0, 1, 0, 0, 0],
  3. [0, 0, 0, 0, 1, 0, 1, 0, 0, 0],
  4. [0, 1, 0, 0, 0, 0, 0, 0, 0, 0],
  5. [0, 0, 0, 1, 0, 1, 1, 0, 0, 0],
  6. [0, 0, 1, 0, 0, 0, 0, 0, 0, 0],
  7. [1, 0, 0, 0, 0, 0, 0, 0, 1, 1],
  8. [0, 0, 0, 1, 0, 0, 0, 0, 1, 0],
  9. [0, 0, 0, 0, 0, 0, 0, 0, 1, 0],
  10. [0, 0, 0, 0, 0, 0, 0, 0, 1, 0]]
  11. col = len(m)
  12. row = len(m[0])
  13. count = 0
  14. def move(i, j):
  15.     try:
  16.         if i >= 0 and j >= 0 and m[i][j] == 1:
  17.             m[i][j] = 2
  18.             move(i - 2, j + 1)
  19.             move(i - 1, j + 2)
  20.             move(i + 1, j + 2)
  21.             move(i + 2, j + 1)
  22.             move(i + 2, j - 1)
  23.             move(i + 1, j - 2)
  24.             move(i - 1, j - 2)
  25.             move(i - 2, j - 1)
  26.     except IndexError:
  27.         pass
  28.         
  29.             
  30.         
  31. for i in range(col):
  32.     for j in range(row):
  33.         if m[i][j] == 1:
  34.             count += 1
  35.             move(i, j)
  36. print(count)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-9-9 22:05:15 | 显示全部楼层
张xiao月 发表于 2018-9-9 21:29
楼主 求一个VIP账号 真的很需要学习C语言的课程 我正在学习C语言

可以把你百度网盘账号给我,我发给你资料
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-9 22:05:39 | 显示全部楼层
冬雪雪冬 发表于 2018-9-9 21:48
用递归比较容易完成。

大神出马还是厉害
            move(i + 1, j + 2)
            move(i + 2, j + 1)
            move(i + 2, j - 1)
            move(i + 1, j - 2)
            move(i -1, j - 2)
move只要5个好像就行
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-9 22:17:00 | 显示全部楼层
冬雪雪冬 发表于 2018-9-9 21:48
用递归比较容易完成。

恩,还是得8个,想省判断,但是好像边界不行
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-9 22:18:32 | 显示全部楼层
塔利班 发表于 2018-9-9 22:05
大神出马还是厉害
            move(i + 1, j + 2)
            move(i + 2, j + 1)

是可以优化,但你的好像还是少了move,这样算出的count是8
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-9 22:19:53 | 显示全部楼层
塔利班 发表于 2018-9-9 22:17
恩,还是得8个,想省判断,但是好像边界不行

m[2][6]没有递归到
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-9-9 23:16:06 | 显示全部楼层
冬雪雪冬 发表于 2018-9-9 21:48
用递归比较容易完成。

大佬真厉害,困扰我好几天了这个
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-11 23:49:59 From FishC Mobile | 显示全部楼层
Bella666 发表于 2018-9-9 22:05
可以把你百度网盘账号给我,我发给你资料

4149689198百度云账号,希望你能加我QQ便于联系交流1776084463
Screenshot_20180911-234722.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-9-21 02:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表