鱼C论坛

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

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

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

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

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

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

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


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

  18. temp=input('请输入表盘上的数字,以空格间隔:\n').split()    #输入表盘初始化数字
  19. list1=[]                #初始化list1,用于记录表盘信息
  20. result=[]               #初始化result,用于记录访问步骤
  21. flag=0                     #初始化flag,用于记录是否找到解谜顺序
  22. for i in temp:list1.append([int(i),1])      #将输入的数字转化为二元列表,1表示该位置还未被访问
  23. list_backup=list1[:]                    #将列表备份
  24. for index in list1:                     #从列表第一个元素开始遍历
  25.     if colck(index)==True:              #如果clock(index)返回值为真,则将flag标记为1
  26.         flag=1
  27.         break
  28.     else:                               #如果clock(index)返回值为假,则重置result和list1,进入下一次循环
  29.         result=[]
  30.         list1=list_backup[:]
  31. if flag==1:                             #如果flag=1,表示找到解,则打印result,否则打印'无解'
  32.     print(result)
  33. else:
  34.     print('没找到合适解')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

  18. temp=input('请输入表盘上的数字,以空格间隔:\n').split()    #输入表盘初始化数字
  19. list1=[]                #初始化list1,用于记录表盘信息
  20. result=[]               #初始化result,用于记录访问步骤
  21. flag=0                     #初始化flag,用于记录是否找到解谜顺序
  22. for i in temp:list1.append([int(i),1])      #将输入的数字转化为二元列表,1表示该位置还未被访问
  23. list_backup=list1[:]                    #将列表备份
  24. for index in list1:                     #从列表第一个元素开始遍历
  25.     if colck(index)==True:              #如果clock(index)返回值为真,则将flag标记为1
  26.         flag=1
  27.         break
  28.     else:                               #如果clock(index)返回值为假,则重置result和list1,进入下一次循环
  29.         result=[]
  30.         list1=list_backup[:]
  31. if flag==1:                             #如果flag=1,表示找到解,则打印result,否则打印'无解'
  32.     print(result)
  33. else:
  34.     print('没找到合适解')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-13 16:58:29 | 显示全部楼层
缩进没对齐
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-13 17:35:21 | 显示全部楼层
居然犯了这么低级的错误,上面一行最右边少了个括号
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-26 15:07

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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