【九度】题目1388:跳台阶 【LeetCode】Climbing Stairs

2024-08-25 12:08

本文主要是介绍【九度】题目1388:跳台阶 【LeetCode】Climbing Stairs,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、【九度】题目1388:跳台阶
时间限制
:1 秒内存限制:32 兆特殊判题:否提交:2435解决:995
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
输入
输入可能包含多个测试样例,对于每个测试案例,
输入包括一个整数n(1<=n<=70)。
输出
对应每个测试案例,
输出该青蛙跳上一个n级的台阶总共有多少种跳法。
样例输入
5
样例输出
8
答疑
解题遇到问题?分享解题心得?讨论本题请访问: http://t.jobdu.com/thread-8111-1-1.html
【解题思路】
以下这个解释参考别人写好的。(地址: http://t.jobdu.com/thread-8111-1-1.html,name:acaiwlj)
*1.当n = 1时,只有一种跳法,s = 1;
*2.当n = 2时,有两种跳法, s = 2;
*3.当n > 2时,有两种分解方法:
*  (1)当第一下跳一个台阶时,s(n) = s(n-1);
*  (2)当第一下条一个台阶时,s(n) = s(n-2);
*因此可以得到递归表达式:
*s(n) = 1, n = 1;
*s(n) = 2, n = 2;
*s(n) = s(n-1) + s(n-1), n > 2;
注意:可以用数组,以空间换时间,也可以用递归,但是递归太慢,会导致很多重复计算。本题采用数组。
其实结果就是斐波那契序列,结果用long,int会溢出。

Java AC

import java.io.StreamTokenizer;public class Main {/** 1388*/public static void main(String[] args) throws Exception {StreamTokenizer st = new StreamTokenizer(System.in);long array[] = new long[80];array[0] = 1;array[1] = 2;for (int i = 2; i < array.length; i++) {array[i] = array[i-1] + array[i-2];}while (st.nextToken() != StreamTokenizer.TT_EOF) {int n = (int) st.nval;System.out.println(array[n-1]);}}
}
/**************************************************************Problem: 1388User: wzqwsrfLanguage: JavaResult: AcceptedTime:70 msMemory:14532 kb
****************************************************************/

C++ AC

#include <stdio.h>
const int maxn = 72;
long array[maxn];
int n;
int main(){while(scanf("%d",&n) != EOF){if(n == 1){printf("1\n");continue;}array[1] = 1;array[2] = 2;for(int i = 3; i < n + 1; i++){array[i] = array[i-1] + array[i-2];}printf("%ld\n", array[n]);}return 0;
}/**************************************************************Problem: 1388User: wangzhenqingLanguage: C++Result: AcceptedTime:0 msMemory:1020 kb
****************************************************************/



2、【LeetCode】Climbing Stairs
Total Accepted: 17976 Total Submissions: 53883 My Submissions
You are climbing a stair case. It takes n steps to reach to the top.
Each time you can either climb 1 or 2 steps. In how many distinct ways can you climb to the top?
Have you been asked this question in an interview? 

Java AC 336ms

public class Solution {public int climbStairs(int n) {if (n == 1) {return 1;}int array[] = new int[n+1];array[1] = 1;array[2] = 2;for(int i = 3; i < n+1; i++){array[i] = array[i-1] + array[i-2];}return array[n];}
}
Python AC 120ms
class Solution:# @param n, an integer# @return an integerdef climbStairs(self, n):if n == 1:return 1array = [0 for i in range(n+1)]array[1] = 1array[2] = 2for i in range(3, n+1):array[i] = array[i-1] + array[i-2]return array[n]



这篇关于【九度】题目1388:跳台阶 【LeetCode】Climbing Stairs的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1105511

相关文章

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L

leetcode-23Merge k Sorted Lists

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode mergeKLists

题目1254:N皇后问题

题目1254:N皇后问题 时间限制:1 秒 内存限制:128 兆 特殊判题:否 题目描述: N皇后问题,即在N*N的方格棋盘内放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在同一斜线上。因为皇后可以直走,横走和斜走如下图)。 你的任务是,对于给定的N,求出有多少种合法的放置方法。输出N皇后问题所有不同的摆放情况个数。 输入

题目1380:lucky number

题目1380:lucky number 时间限制:3 秒 内存限制:3 兆 特殊判题:否 提交:2839 解决:300 题目描述: 每个人有自己的lucky number,小A也一样。不过他的lucky number定义不一样。他认为一个序列中某些数出现的次数为n的话,都是他的lucky number。但是,现在这个序列很大,他无法快速找到所有lucky number。既然

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(