鱼C论坛

 找回密码
 立即注册
查看: 1090|回复: 2

小乌龟走路问题

[复制链接]
发表于 2020-6-22 19:59:21 | 显示全部楼层 |阅读模式

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

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

x
有一个小乌龟,有两个指令可以控制它,一个是T,一个是F。 T的含义是转身(180度), F的含义是向前走一步。假设你已经知道了一些指令(例如:FFFTFF),你需要对这个序列修改n次,修改一次代表将一个位置的T变成F,
或者是F变成T,问 按照修改n次后的指令,小乌龟能到达的最远距离。

例子:s = "FFTFF"  n = 1, 最远距离是5(把T变成F)

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-6-22 21:04:19 | 显示全部楼层
def func(s, n):
        return s.replace("T", "F", n).count("F")
不经过大脑思考写出的代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-22 21:16:48 | 显示全部楼层
当然地球人都知道,每一步都是F是最大的
程序的话,好像很麻烦:需要每一个路径(所谓FT,正好对应二进制),如果3步,就是8种情况,bit函数用来生成(0,1)的N位全排列,接下来就是对每一个排列的行,按照0转动,1前进,进行模拟,最后计算结果,把最大距离那个保存起来,最后用比如是(11111),其实就是(FFFFF)和给定的指令(例如:FFFTFF)作比较,差了几位,就是需要改几步
def bit(num = 8, state = ()):
        for pos in range(2):
                if len(state) == num - 1:
                        yield (pos,)
                else:
                        for result in bit(num, state + (pos,)):
                                yield (pos,) + result

one_step=(1,-1)
max_pos = 0
max_step = None
for res in bit(3):
    pos = 0
    direct = 0
    for step in res:
        if step == 0:
            direct += 1
        else:
            pos += one_step[direct % 2]
    if abs(pos) > max_pos:
        max_pos = abs(pos)
        max_step = res
print(max_pos,max_step)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-20 12:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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