当前位置: 首页 > news >正文

武汉代理记账企业网站如何优化

武汉代理记账,企业网站如何优化,网站倒计时怎么做的,深圳有几个区分布图机器人走路 假设有排成一行的N个位置记为1~N,N一定大于或等于2 开始时机器人在其中的start位置上(start一定是1~N中的一个) 如果机器人来到1位置,那么下一步只能往右来到2位置; 如果机器人来到N位置,那么下一步只能往左来到N-1位…

机器人走路

假设有排成一行的N个位置记为1~N,N一定大于或等于2
开始时机器人在其中的start位置上(start一定是1~N中的一个)
如果机器人来到1位置,那么下一步只能往右来到2位置;
如果机器人来到N位置,那么下一步只能往左来到N-1位置;
如果机器人来到中间位置,那么下一步可以往左走或者往右走;
规定机器人必须走K步,最终能来到aim位置(P也是1~N中的一个)的方法有多少种
给定四个参数 N,start,aim,K 返回能走到的方法数

递归思路

1、当cur在1位置时,只能向2位置移动
2、当cur在N位置时,只能向N-1位置移动
3、当cur在中间位置,可以向cur+1位置移动、也可以向cur-1位置移动
4、如果剩余步数刚好走完时,来到目标位置,返回1,否则返回0

class RobotWalk(object):def ways_a(self, pos, steps, start, target):""":param pos: 总共有pos个位置:param steps: 可以走的步数:param start: 开始位置:param target: 目标位置:return:"""if pos < 2 or steps < 1 or start < 1 or start > pos or target < 1 or target > pos:return 0return self.process_a(pos, start, steps, target)def process_a(self, pos, cur, rest, target):""":param pos: 总共有pos个位置:param cur: 当前来到的位置:param rest: 还剩下的步数:param target: 目标位置:return: 机器人从cur出发,走过rest步之后,最终停留在target的方法数"""# 步数走完时,如果机器人刚好到达目标位置,则返回1if rest == 0:return 1 if cur == target else 0# 如果在1位置,只能向右走 -> cur+1if cur == 1:return self.process_a(pos, cur + 1, rest - 1, target)# 如果在最后一个位置,只能向左 -> cur-1if cur == pos:return self.process_a(pos, cur - 1, rest - 1, target)# 中间位置 既能向左又能向右return self.process_a(pos, cur + 1, rest - 1, target) + self.process_a(pos, cur - 1, rest - 1, target)

动态规划

加缓存

class RobotWalk(object):def ways_b(self, pos, steps, start, target):""":param pos: 总共有pos个位置:param steps: 可以走的步数:param start: 开始位置:param target: 目标位置:return:"""if pos < 2 or steps < 1 or start < 1 or start > pos or target < 1 or target > pos:return 0# 转移条件 剩下的步数 和 当前位置# 当前位置cur 范围 1~pos# 剩余步数rest 范围 0~steps# steps(总步数) 列 pos(总共位置数) 行的数组cache = [[-1] * (steps + 1) for _ in range(pos + 1)]return self.process_b(pos, start, steps, target, cache)def process_b(self, pos, cur, rest, target, cache):"""加缓存减少重复计算:param pos::param cur::param rest::param target::param cache::return:"""# 当前位置没有计算过,则计算后存入缓存,否则直接返回缓存数据if cache[cur][rest] == -1:# 步数走完时,如果机器人刚好到达目标位置,则返回1if rest == 0:index = 1 if cur == target else 0elif cur == 1:index = self.process_b(pos, 2, rest - 1, target, cache)elif cur == pos:index = self.process_b(pos, pos - 1, rest - 1, target, cache)else:index = self.process_b(pos, cur + 1, rest - 1, target, cache) + \self.process_b(pos, cur - 1, rest - 1, target, cache)cache[cur][rest] = indexreturn cache[cur][rest]

假如:
位置数 pos=6
剩余步数steps=5
开始位置start=1
目标位置target=4
cur为当前位置
创建动态表dp 行代表位置数 pos(1,pos), 列代表剩余步数rest(0,steps)
根据递归条件填表:
1、当剩余步数为0时,刚好来到target位置,dp值为1,如果在其他位置,说明未到目标位置,dp值为0
即:dp[cur][rest] = dp[4][0] = 1
2、当cur=1时,只能向2位置移动,都依赖dp[2][rest-1]位置的值
3、当cur=pos时,只能向pos-1位置移动,都依赖dp[pos-1][rest-1]位置的值
4、当1<cur<pos时,既能向cur-1位置移动,也能向cur+1位置移动,都依赖dp[cur-1][rest-1]+dp[cur+1][rest-1]
最终求dp[start][rest] --> dp[1][5] = 4

| cur/rest

位置/剩余步数012345
0xxxxxx
1000104
2001040
30103010
4102060
5010309
6001030

代码实现

class RobotWalk(object):def ways_c(self, pos, steps, start, target):""":param pos: 总共有pos个位置:param steps: 可以走的步数:param start: 开始位置:param target: 目标位置:return:"""if pos < 2 or steps < 1 or start < 1 or start > pos or target < 1 or target > pos:return 0# 当前位置cur 范围 1~pos# 剩余步数rest 范围 0~steps# steps(总步数) 列 pos(总共位置数) 行的数组dp = [[0] * (steps + 1) for _ in range(pos + 1)]# 当剩余0步时,刚好来到target位置 则dp值为1, 其他位置值为0dp[target][0] = 1# 列for col in range(1, steps + 1):# 第一行依赖左下元素dp[1][col] = dp[2][col - 1]# 中间行依赖左下和左上for row in range(1, pos):dp[row][col] = dp[row + 1][col - 1] + dp[row - 1][col - 1]# 最末行依赖左上元素dp[pos][col] = dp[pos - 1][col - 1]return dp[start][steps]
http://www.tj-hxxt.cn/news/41863.html

相关文章:

  • 做网站总结中国关键词官网
  • 河源抖音seo讯息网站推广优化方式
  • 网站建设社团活动宗旨网站平台做推广
  • 一个网站怎么做软件好用吗免费b站推广入口
  • 网站后台怎么制作开发网站建设公司
  • 做网站哪家好哪家好直通车关键词优化
  • 网站建设项目风险管理的主要内容google推广公司哪家好
  • 昆明网站建设公司电话aso是什么意思
  • 上海网站关键词优化最近最火的关键词
  • 推推蛙网站建设成都百度推广排名优化
  • py网站开发视频教程帮人推广注册app的平台
  • 网页设计与网站建设第2章在线测试网址缩短在线生成器
  • 如何做网站需求表格清单创建网站平台
  • 小程序有做门户网站2024年新闻摘抄十条
  • 赤峰网站建设哪家好太原百度公司地址
  • 淘宝开放平台怎么做淘宝客网站免费找精准客户的app
  • 做淘宝要网站?天天网站
  • 做UI设计的网站网络营销的内容
  • 蛋糕网站设计广东seo推广方案
  • 郑州企业建设网站有什么用南宁seo收费
  • 微信oa系统网站的seo
  • 套别人的网站模板网络营销模式案例
  • 网站开发 职位描述杭州关键词优化外包
  • wordpress电子商务中文主题安卓优化清理大师
  • 北京专业网站制作技术媒体发稿推广
  • 化妆品网站下载抖音seo优化系统招商
  • 做网站哪一部分用到Java黄冈seo顾问
  • 做网站可以赚钱吗佛山营销型网站建设公司
  • 山西城乡和住房建设厅网站首页郑州网站排名推广
  • 叫别人做网站要多久百度灰色关键词技术