標題:
遞迴函式 (二) - 費氏數列
[打印本頁]
作者:
tonyh
時間:
2019-8-7 11:37
標題:
遞迴函式 (二) - 費氏數列
費氏數列 - 維基百科
費氏數列規則如下:
第n項 = 第 n-1 項 + 第 n-2 項
即整個費式數列為:
0 1 1 2 3 5 8 13 21 34 55 89 144 233 377...
試完成一程式,能推算費氏數列至指定項次:
import java.util.Scanner;
public class Ch50 {
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);
}
/*
值: 0 1 1 2 3 5 8
項: 0 1 2 3 4 5 6
fai(5)
=fai(3)+fai(4)
=fai(1)+fai(2)+fai(2)+fai(3)
=1+fai(0)+fai(1)+fai(0)+fai(1)+fai(1)+fai(2)
=1+0+1+0+1+1+fai(0)+fai(1)
=1+0+1+0+1+1+0+1
=5
*/
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次? ");
n=s.nextInt();
for(int i=0; i<=n; i++)
{
System.out.print(fai(i)+" ");
}
}
}
複製代碼
作者:
張書涵
時間:
2019-8-7 13:24
import java.util.Scanner;
public class Ch01 {
static int f(int a)
{
if(a==0)
return 0;
if(a==1)
return 1;
else
return f(a-2)+f(a-1);
}
public static void main(String[] args) {
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏樹列到第幾項? ");
n=s.nextInt();
for(int i=0; i<=n; i++)
{
System.out.print(f(i)+" ");
}
}
}
複製代碼
作者:
張郁庭
時間:
2019-8-7 13:26
import java.util.Scanner;
public class Ch04 {
static int fai(int n)
{
if(n<2)
return 0;
else
return fai(n-1);
}
public static void main(String[] args) {
int n;
Scanner s=new Scanner(System.in);
System.out.println("請問要推算費式數列到第幾項次? ");
n=s.nextInt();
for(int i=0; i<=n; i++)
System.out.println(fai(i)+" ");
}
}
複製代碼
作者:
潘憶承
時間:
2019-8-7 13:29
本帖最後由 潘憶承 於 2019-8-7 13:31 編輯
import java.util.Scanner;
public class Ch01{
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);
}
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.println("請問要推算費氏數列到第幾項次?");
n=s.nextInt();
for(int i=0;i<=n;i++)
{
System.out.println(fai(i)+" ");
}
}
}
複製代碼
作者:
黃永恩
時間:
2019-8-7 13:30
import java.util.Scanner;
public class ch02 {
static int f(int a){
if(a<2)
return a;
else
return f(a-1)+f(a-2);
}
public static void main(String args[]){
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次?");
n=s.nextInt();
for(int i=0;i<n;i++)
System.out.print(f(i)+" ");
}
}
複製代碼
作者:
許育慈
時間:
2019-8-7 13:30
本帖最後由 許育慈 於 2019-8-7 13:31 編輯
import java.util.Scanner;
public class Ch01 {
static int f(int a){
if(a<=1)
return a;
else
return f(a-1)+f(a-2);
}
public static void main(String[] args) {
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次?");
int w=s.nextInt();
for(int i=0;i<=w;i++)
System.out.print(f(i)+" ");
}
}
複製代碼
作者:
莊鈞程
時間:
2019-8-7 13:30
import java.util.Scanner;
import java.util.Arrays;
public class Ch50 {
static int fib(int n){
if(n<2)
return n;
else
return fib(n-1)+fib(n-2);
}
public static void main(String args[]){
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次? ");
n=s.nextInt();
for(int i=0;i<=n;i++)
System.out.print(fib(i)+" ");
}
}
複製代碼
作者:
許育禎
時間:
2019-8-7 13:30
import java.util.Scanner;
public class CH01 {
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);
}
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次?");
n=s.nextInt();
for(int i=0;i<=n;i++)
System.out.print(fai(i)+" ");
}
}
複製代碼
作者:
李沛儒
時間:
2019-8-7 13:30
import java.util.Scanner;
public class Ch000
{
static int fai(int a)
{
if( a<2 )
return a;
else
return fai(a-2)+fai(a-1);
}
public static void main(String args[])
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費是數列至第幾項? ");
n=s.nextInt();
for(int i=0 ; i<=n ; i++)
{
System.out.println(fai(i)+" ");
}
}
}
複製代碼
作者:
葉俠愷
時間:
2019-8-7 13:30
import java.util.Scanner;
public class Ch11 {
static int f(int b)
{
if(b<2)
{
return b;
}else
{
return f(b-1)+f(b-2);
}
}
public static void main(String[] args) {
Scanner s=new Scanner(System.in);
int b;
System.out.println("幾次費氏數列");
b=s.nextInt();
System.out.println(b+"次費氏數列為"+f(b));
}
}
複製代碼
作者:
張嘉栩
時間:
2019-8-7 13:31
import java.util.Scanner;
public class Ch01
{
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);}
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("要推算費氏數列到第幾項??? ");
n=s.nextInt();
for(int i=0; i<=n; i++)
{
System.out.print(fai(i)+" ");
}
}
}
複製代碼
作者:
蔡明蓉
時間:
2019-8-7 13:31
import java.util.Scanner;
public class Ch10 {
static int fai(int n){
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);
}
public static void main(String[] args) {
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次? ");
n=s.nextInt();
for(int i=0;i<=n;i++){
System.out.print(fai(i)+" ");
}
}
}
複製代碼
作者:
鄭宇崴
時間:
2019-8-7 13:33
import java.util.Scanner;
public class Ch51{
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);
}
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次?");
n=s.nextInt();
for(int i=0;i<=n;i++)
{
System.out.print(fai(i)+" ");
}
}
}
複製代碼
作者:
余奕廷
時間:
2019-8-7 13:33
import java.util.Scanner;
public class Ch01 {
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-1)+fai(n-2);
}
public static void main(String[] args) {
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次? ");
int a=s.nextInt();
for(int i=0; i<=a; i++)
System.out.print(fai(i)+" ");
}
}
複製代碼
作者:
曾暘竣
時間:
2019-8-7 13:33
public class Ch10 {
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);
}
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("要推算費氏數列到第幾項次? ");
n=s.nextInt();
for(int i=0; i<=n; i++)
{
System.out.print(fai(i)+" ");
}
}
}
複製代碼
作者:
黃芊嬡
時間:
2019-8-7 13:36
import java.util.Scanner;
public class Ch01
{
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+(n-1);
}
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項?");
n=s.nextInt();
for(int i=0;i<=n;i++)
{
System.out.print(fai(i)+" ");
}
}
}
複製代碼
作者:
余映均
時間:
2019-8-7 13:36
import java.util.Scanner;
public class Ch02 {
static int fai(int n)
{
if(n<2)
{
return n;
}else
{
return fai(n-1)+fai(n-2);
}
}
public static void main(String[] args) {
Scanner s=new Scanner(System.in);
int n;
System.out.print("請問要推算費氏數列到第幾項次? ");
n=s.nextInt();
for(int i=0;i<=n;i++)
System.out.println(fai(i)+" ");
}
}
複製代碼
作者:
何育翔
時間:
2019-8-7 13:38
import java.util.Scanner;
public class Ch01{
static int fai(int n)
{
if(n<2)
return n;
else
return fai(n-2)+fai(n-1);
}
public static void main(String[] args)
{
int n;
Scanner s=new Scanner(System.in);
System.out.print("請問要推算費氏數列到第幾項次?");
n=s.nextInt();
for(int i=0;i<=n;i++)
{
System.out.print(fai(i)+" ");
}
}
}
複製代碼
歡迎光臨 種子論壇 | 高雄市資訊培育協會學員討論區 (http://istak.org.tw/seed/)
Powered by Discuz! 7.2