鱼C论坛

 找回密码
 立即注册
12
返回列表 发新帖
楼主: 冬雪雪冬

[技术交流] Python:每日一题 123

[复制链接]
发表于 2020-6-8 14:10:58 | 显示全部楼层
本帖最后由 uune 于 2020-6-8 14:12 编辑
  1. list1 = [1, 1, 1, 2, 1, 1, 2, 4, 4, 3,
  2.          2, 1, 1, 1, 1, 1, 1, 1, 4, 2,
  3.          1, 2, 3, 1, 4, 2, 1, 1, 2, 4,
  4.          2, 1, 1, 1, 1, 1, 2, 1, 4, 1,
  5.          1, 1, 1, 3, 2, 2, 3, 1, 2, 3,
  6.          3, 2, 4, 1, 1, 1, 1, 1, 1, 4,
  7.          2, 1, 1, 1, 1, 2, 2, 1, 4, 1,
  8.          1, 2, 1, 3, 2, 1, 2, 4, 1, 4,
  9.          1, 2, 1, 1, 1, 1, 4, 2, 2, 2,
  10.          2, 1, 2, 1, 2, 2, 3, 4, 1, 1]

  11. flag = -1           #为了记录第0个格子设置为-1
  12. direction = 1       #默认向右走,+1
  13. dex = []            #记录走过的格子
  14. n = 0               #步数

  15. #从哪边来的专向后该去那边
  16. s2 = {1:10, 10:-1, -1:-10, -10:1}
  17. s4 = {-10:-1, -1:10, 10:1, 1:-10}

  18. while flag != 99:
  19.     n += 1
  20.    
  21.     #右转
  22.     if list1[flag] == 2:
  23.         direction = s2.get(direction)

  24.     #掉头
  25.     elif list1[flag] == 3:
  26.         direction = 0-direction
  27.    
  28.     #左转
  29.     elif list1[flag] == 4:
  30.         direction = s4.get(direction)
  31.         
  32.     #直走
  33.     flag += direction
  34.     print('现在位置是:',flag)

  35.     dex.append(flag)

  36. #去重
  37. dex = list(set(dex))
  38. print('一共走了%d步'%n)
  39. #求和
  40. print('走过的格子的数字相加:',sum([list1[i] for i in dex]))
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-30 17:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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