国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

上樓梯問題

2019-11-14 09:11:22
字體:
來源:轉載
供稿:網友
 

超級樓梯

Time Limit: 2000/1000 MS (java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 55367    Accepted Submission(s): 28142PRoblem Description有一樓梯共M級,剛開始時你在第一級,若每次只能跨上一級或二級,要走上第M級,共有多少種走法? Input輸入數據首先包含一個整數N,表示測試實例的個數,然后是N行數據,每行包含一個整數M(1<=M<=40),表示樓梯的級數。 Output對于每個測試實例,請輸出不同走法的數量 Sample Input
223 Sample Output
12 Authorlcy Source2005實驗班短學期考試 Recommendlcy開始我是用回溯法,把這個問題抽象成完全二叉樹,每次有兩條路可以走,走第一條減1,走第二條減2,當走完后,就標記count++,完了就回溯,還有當走過了即出現(xiàn)負數了也要回溯,c代碼如下#include<stdio.h>int count=0;int a;void deep(int n){if(a==n) count=0;if(n==0){ count++;return;//回溯}elseif(n>0){deep(n-1);deep(n-2);}elsereturn;走過了也回溯}int main(){int n;scanf("%d",&n);while(n--){scanf("%d",&a);a=a-1;//只到第一級!!deep(a);printf("%d/n",count);}}本來可以了,可想到時間超限了!!!!最后想到是斐波那契數列,1+1=2,1+2=3,2+3=5........然后有下面代碼#include<stdio.h>int a[100];int deep(int n){int p;if(a[n]>0)return a[n];if(n==1)return 1;if(n==2)return 1;if(n>2)a[n]=deep(n-1)+deep(n-2);return a[n];}int main(){int n,sum,a;scanf("%d",&n);while(n--){scanf("%d",&a);sum=deep(a);printf("%d/n",sum);}}時間又超限了!!!!!也是,出現(xiàn)在遞歸函數里的式子經過遞歸后是一樣的,也就是要再算,這就會多算了幾道,所以時間超限,我們可以再定義一個數組,里面都是0,當遞歸后存一遍算后的值,防止多算,只算一遍#include<stdio.h>int a[100];int deep(int n){int p;if(a[n]>0)return a[n];if(n==1)return 1;if(n==2)return 1;if(n>2)a[n]=deep(n-1)+deep(n-2);return a[n];}int main(){int n,sum,a;scanf("%d",&n);while(n--){scanf("%d",&a);sum=deep(a);printf("%d/n/n",sum);}}
上一篇:素數篩法

下一篇:JavaDoc學習筆記

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 澄迈县| 惠安县| 资兴市| 比如县| 杭锦旗| 伊金霍洛旗| 和硕县| 苏州市| 阆中市| 丰台区| 江孜县| 禄劝| 青海省| 冀州市| 珲春市| 原阳县| 石城县| 湖北省| 玉溪市| 溧水县| 大宁县| 汉源县| 陵川县| 沙洋县| 扬中市| 谷城县| 乐陵市| 马尔康县| 伊金霍洛旗| 怀集县| 修水县| 桃园县| 景宁| 元朗区| 鹿邑县| 周宁县| 肥乡县| 东明县| 富顺县| 信宜市| 彭州市|