鱼C论坛

 找回密码
 立即注册
查看: 1258|回复: 3

[已解决]做了个FF13-2里的时钟谜题计算器,一直提示语法错误

[复制链接]
发表于 2021-3-13 15:47:48 | 显示全部楼层 |阅读模式

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

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

x
根据游戏FF13-2里的时钟谜题,做了个计算器,来计算解谜路径,但是编译的时候一直提示语法错误,但是有看不出来哪里错了,请教各位大神指点
def clock(i):
    if list1[i][1] != 0:   #判断当前位置是否访问过
        num = list1[i][0]  #记录当前位置的值
        list1[i][1] = 0    #将当前位置修改标识置为0,表示已访问
        result.append(i)   #将当前位置加入记录
        index_R = (i+num)%len(list1)   #计算向右下一个指针位置
        if i<num :                         ##计算向左下一个指针位置
            index_L = (i-num)%(-len(list1)
               else:
            index_L = (i-num)%len(list1)
        #index_L = (i-num)%(-len(list1) if i<num else (i-num)%len(list1)  #计算向左下一个指针位置
        if clock(index_R) == True:          #判断右向新位置是否未访问
            return True
        elif clock(index_L):                #判断左向新位置是否未访问
            return True
        else:                               #左右皆访问过,则返回False
            return False

temp=input('请输入表盘上的数字,以空格间隔:\n').split()    #输入表盘初始化数字
list1=[]                #初始化list1,用于记录表盘信息
result=[]               #初始化result,用于记录访问步骤
flag=0                     #初始化flag,用于记录是否找到解谜顺序
for i in temp:list1.append([int(i),1])      #将输入的数字转化为二元列表,1表示该位置还未被访问
list_backup=list1[:]                    #将列表备份
for index in list1:                     #从列表第一个元素开始遍历
    if colck(index)==True:              #如果clock(index)返回值为真,则将flag标记为1
        flag=1
        break
    else:                               #如果clock(index)返回值为假,则重置result和list1,进入下一次循环
        result=[]
        list1=list_backup[:]
if flag==1:                             #如果flag=1,表示找到解,则打印result,否则打印'无解'
    print(result)
else:
    print('没找到合适解')

编译的时候提示第9行“else:”为无效语法,麻烦各位大神帮忙看看哪的问题
最佳答案
2021-3-13 15:55:41
def clock(i):
    if list1[i][1] != 0:   #判断当前位置是否访问过
        num = list1[i][0]  #记录当前位置的值
        list1[i][1] = 0    #将当前位置修改标识置为0,表示已访问
        result.append(i)   #将当前位置加入记录
        index_R = (i+num)%len(list1)   #计算向右下一个指针位置
        if i<num :                         ##计算向左下一个指针位置
            index_L = (i-num)%(-len(list1))
        else:
            index_L = (i-num)%len(list1)
        #index_L = (i-num)%(-len(list1) if i<num else (i-num)%len(list1)  #计算向左下一个指针位置
        if clock(index_R) == True:          #判断右向新位置是否未访问
            return True
        elif clock(index_L):                #判断左向新位置是否未访问
            return True
        else:                               #左右皆访问过,则返回False
            return False

temp=input('请输入表盘上的数字,以空格间隔:\n').split()    #输入表盘初始化数字
list1=[]                #初始化list1,用于记录表盘信息
result=[]               #初始化result,用于记录访问步骤
flag=0                     #初始化flag,用于记录是否找到解谜顺序
for i in temp:list1.append([int(i),1])      #将输入的数字转化为二元列表,1表示该位置还未被访问
list_backup=list1[:]                    #将列表备份
for index in list1:                     #从列表第一个元素开始遍历
    if colck(index)==True:              #如果clock(index)返回值为真,则将flag标记为1
        flag=1
        break
    else:                               #如果clock(index)返回值为假,则重置result和list1,进入下一次循环
        result=[]
        list1=list_backup[:]
if flag==1:                             #如果flag=1,表示找到解,则打印result,否则打印'无解'
    print(result)
else:
    print('没找到合适解')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-3-13 15:55:41 | 显示全部楼层    本楼为最佳答案   
def clock(i):
    if list1[i][1] != 0:   #判断当前位置是否访问过
        num = list1[i][0]  #记录当前位置的值
        list1[i][1] = 0    #将当前位置修改标识置为0,表示已访问
        result.append(i)   #将当前位置加入记录
        index_R = (i+num)%len(list1)   #计算向右下一个指针位置
        if i<num :                         ##计算向左下一个指针位置
            index_L = (i-num)%(-len(list1))
        else:
            index_L = (i-num)%len(list1)
        #index_L = (i-num)%(-len(list1) if i<num else (i-num)%len(list1)  #计算向左下一个指针位置
        if clock(index_R) == True:          #判断右向新位置是否未访问
            return True
        elif clock(index_L):                #判断左向新位置是否未访问
            return True
        else:                               #左右皆访问过,则返回False
            return False

temp=input('请输入表盘上的数字,以空格间隔:\n').split()    #输入表盘初始化数字
list1=[]                #初始化list1,用于记录表盘信息
result=[]               #初始化result,用于记录访问步骤
flag=0                     #初始化flag,用于记录是否找到解谜顺序
for i in temp:list1.append([int(i),1])      #将输入的数字转化为二元列表,1表示该位置还未被访问
list_backup=list1[:]                    #将列表备份
for index in list1:                     #从列表第一个元素开始遍历
    if colck(index)==True:              #如果clock(index)返回值为真,则将flag标记为1
        flag=1
        break
    else:                               #如果clock(index)返回值为假,则重置result和list1,进入下一次循环
        result=[]
        list1=list_backup[:]
if flag==1:                             #如果flag=1,表示找到解,则打印result,否则打印'无解'
    print(result)
else:
    print('没找到合适解')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-13 16:58:29 | 显示全部楼层
缩进没对齐
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-13 17:35:21 | 显示全部楼层
居然犯了这么低级的错误,上面一行最右边少了个括号
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 06:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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