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

首頁 > 學院 > 開發設計 > 正文

上樓梯問題

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

超級樓梯

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++,完了就回溯,還有當走過了即出現負數了也要回溯,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);}}時間又超限了!!!!!也是,出現在遞歸函數里的式子經過遞歸后是一樣的,也就是要再算,這就會多算了幾道,所以時間超限,我們可以再定義一個數組,里面都是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);}}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南投县| 鲁山县| 临潭县| 德江县| 舞钢市| 淮北市| 朔州市| 宜城市| 湛江市| 顺平县| 从化市| 新疆| 积石山| 信丰县| 武夷山市| 迁西县| 台前县| 商都县| 张掖市| 灵川县| 桑植县| 新乐市| 绍兴市| 柏乡县| 穆棱市| 西乡县| 扬中市| 玉林市| 衡阳县| 靖西县| 孝感市| 太保市| 柳江县| 合川市| 容城县| 新郑市| 阳西县| 宁安市| 南陵县| 长乐市| 林口县|