class Program
{
int i;
int Fibo(int i){
if(i < 1) return 0;
else if(i == 1 || i == 2)
return 1;
else return Fibo(i - 1) + Fibo(i - 2);
}
static void Main(string[] args)
{
//一列数的规则如下: 1、1、2、3、5、8、13、21、34...
//求第30位数是多少, 用递归算法实现。
Console.Write(Fibo(30));
Console.ReadLine();
}
}Main函数中调用Fibo出错:非静态的字段、方法或属性要求对象引用
因为Main是静态方法,非静态方法可以访问类中的任何成员,静态方法只能访问类中的静态成员。
solution1:在Main函数中创造Program类的实例对象然后调用,Fibo(),因为非静态方法只能在实例化之后才在内存中分配空间。
Program program = new Program();
Console.Write(program.Fibo(30));
solution2:把Fibo()定义为static类型的,即可在Main方法中直接调用:
static int Fibo(int i)
本文详细介绍了使用递归算法求解斐波那契数列的第30位数的方法,通过创建类实例并调用非静态方法来避免在静态方法中直接调用非静态方法导致的错误。
1414

被折叠的 条评论
为什么被折叠?



