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

3154. 到达第 K 级台阶的方案数

Powered by:NEFU AB-IN

Link

文章目录

  • 3154. 到达第 K 级台阶的方案数
    • 题意
    • 思路
    • 代码

3154. 到达第 K 级台阶的方案数

题意

给你有一个 非负 整数 k 。有一个无限长度的台阶,最低 一层编号为 0 。

Alice 有一个整数 jump ,一开始值为 0 。Alice 从台阶 1 开始,可以使用 任意 次操作,目标是到达第 k 级台阶。假设 Alice 位于台阶 i ,一次 操作 中,Alice 可以:

向下走一级到 i - 1 ,但该操作 不能 连续使用,如果在台阶第 0 级也不能使用。
向上走到台阶 i + 2jump 处,然后 jump 变为 jump + 1 。
请你返回 Alice 到达台阶 k 处的总方案数。

注意,Alice 可能到达台阶 k 处后,通过一些操作重新回到台阶 k 处,这视为不同的方案。

思路

记忆化搜索,由于到了目标台阶还可以操作,那么方案的终止就不是等于台阶数,应该是大于目标台阶数,且无法退回来
is_back 表示是否用了后退的机会

代码

'''
Author: NEFU AB-IN
Date: 2024-08-20 15:14:55
FilePath: \LeetCode\3154\3154.py
LastEditTime: 2024-08-20 16:04:34
'''
# 3.8.19 import
import random
from collections import Counter, defaultdict, deque
from datetime import datetime, timedelta
from functools import lru_cache, reduce
from heapq import heapify, heappop, heappush, nlargest, nsmallest
from itertools import combinations, compress, permutations, starmap, tee
from math import ceil, comb, fabs, floor, gcd, hypot, log, perm, sqrt
from string import ascii_lowercase, ascii_uppercase
from sys import exit, setrecursionlimit, stdin
from typing import Any, Callable, Dict, List, Optional, Tuple, TypeVar, Union# Constants
TYPE = TypeVar('TYPE')
N = int(2e5 + 10)
M = int(20)
INF = int(1e12)
OFFSET = int(100)
MOD = int(1e9 + 7)# Set recursion limit
setrecursionlimit(int(2e9))class Arr:array = staticmethod(lambda x=0, size=N: [x() if callable(x) else x for _ in range(size)])array2d = staticmethod(lambda x=0, rows=N, cols=M: [Arr.array(x, cols) for _ in range(rows)])graph = staticmethod(lambda size=N: [[] for _ in range(size)])class Math:max = staticmethod(lambda a, b: a if a > b else b)min = staticmethod(lambda a, b: a if a < b else b)class Std:pass# ————————————————————— Division line ——————————————————————class Solution:def waysToReachStair(self, k: int) -> int:@lru_cache(None)def dfs(n: int, is_back: bool, jump: int):if n - int(not is_back) > k:return 0res = int(n == k)# down firstif not is_back and n:res += dfs(n - 1, True, jump)res += dfs(n + 2 ** jump, False, jump + 1)return resres = dfs(1, False, 0)dfs.cache_clear()return res

http://www.mrgr.cn/news/2436.html

相关文章:

  • http 请求-04-promise 对象 + async/await 入门介绍
  • 【计算机网络】应用层自定义协议与序列化
  • 工业相机错峰启动优化方案
  • 计算机毕业设计选题推荐-旅游景点数据分析-Python爬虫可视化
  • Keepalived总结笔记
  • 8.20Qt作业
  • SEO之网站结构优化(十二-绝对路径和相对路径)
  • Java 的访问控制修饰符
  • 【区块链+商贸零售】NOCO 企业数字化社区 | FISCO BCOS应用案例
  • 【PB案例学习笔记】-33 PB连接Oracle数据库查询数据
  • 如何运用独特的产业运营体系打造一流的数字媒体产业园
  • 客车制造5G智能工厂工业物联数字孪生平台,推进制造业数字化转型
  • 指针和引用的区别
  • MySQL常用方法速通
  • python下载b站视频
  • 大数据量实现滚动分页-vue3+element-plus实现方式
  • 后端Java秋招面试中的自我介绍需要说什么?
  • nginx核心配置示例
  • Go语言基础--switch
  • 第3章处理机调度与死锁