當前位置:首頁 » 編程語言 » 用c語言計算n階勒讓德
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

用c語言計算n階勒讓德

發布時間: 2023-04-08 00:15:55

c語言用遞歸方法求n階勒讓德多項式的值

代碼:

#include<stdio.h>

#include<stdlib.h>

double polya(n,x);

int main()

{

int x,n;

scanf("%d%d",&n,&x);

printf("%.2f ",polya(n,x));

return 0;

}

double polya(int n,int x)

{

double y;

if(n==0)

y=1;

if(n==1)

y=x;

if(n>1)

y=((2*n-1)*x*polya(n-1,x)-(n-1)*polya(n-2,x))/n;

return y;

}

運行結果:

(1)用c語言計算n階勒讓德擴展閱讀:

return

C++的關鍵字,它提供了終止函數執行的一種方式。當return語句提供了一個值時,這個值就成為函數的返回值.

說到return,有必要提及主函數的定義,下面是從網路上找到的資料,好好消化吧,對了解主函數中返回值的理解有很大的幫助.

很多人甚至市面上的一些書籍,都使用了void main(),其實這是錯誤的。C/C++中從來沒有定義過void main()。

C++之父Bjarne Stroustrup在他的主頁上的FAQ中明確地寫著The definition void main(){/*...*/}is not and never has been C++,

nor has it even been C.(void main()從來就不存在於C++或者C)。下面我分別說一下C和C++標准中對main函數的定義。

1.C

在C89中,main()是可以接受的。Brian W.Kernighan和Dennis M.Ritchie的經典巨著The C programming Language 2e(《C程序設計語言第二版》)用的就是main()。不過在最新的C99標准中,只有以下兩種定義方式是正確的:

int main(void)

int main(int argc,char*argv[])

(參考資料:ISO/IEC 9899:1999(E)Programming languages—C 5.1.2.2.1 Program startup)

當然,我們也可以做一點小小的改動。例如:char*argv[]可以寫成char**argv;argv和argc可以改成別的變數名(如intval和charval),不過一定要符合變數的命名規則。

如果不需要從命令行中獲取參數,請用int main(void);否則請用int main(int argc,char*argv[])。

main函數的返回值類型必須是int,這樣返回值才能傳遞給程序的激活者(如操作系統)。

如果main函數的最後沒有寫return語句的話,C99規定編譯器要自動在生成的目標文件中(如exe文件)加入return 0;,表示程序正常退出。不過,我還是建議你最好在main函數的最後加上return語句,雖然沒有這個必要,但這是一個好的習慣。

注意,vc6不會在目標文件中加入return 0;,大概是因為vc6是98年的產品,所以才不支持這個特性。現在明白我為什麼建議你最好加上return語句了吧!不過,gcc3.2(Linux下的C編譯器)會在生成的目標文件中加入return 0;。

② c語言:用遞歸方法編寫程序,求n階勒讓德多項式的值

#define _CRT_SECURE_NO_WARNINGS

#include<stdio.h>

#include<stdlib.h>

double legendre(int n, int x) {

if (n == 0) {

return 1;

}

if (n == 1) {

return x;

}

return ((2 * n - 1)*x - legendre(n - 1, x) - (n - 1)*legendre(n - 2, x)) / n;

}

void main() {

int n;

int x;

printf("請輸入n的值和x的值 ");

scanf("%d %d", &n, &x);

printf("P%d(%d) = %f ", n, x, legendre(n, x));

system("pause");

}

③ c語言應用遞歸函數求解N階勒讓德多項式

你所貼程序中,函數p不是遞歸函數。遞歸函數是自己調用自己,遇到結束條件後向前層層返回。
double legendre(int n, int x)
{
if (n == 0) return 1; // 結束條件
if (n == 1) return x;
return ((2*n-1)*x - legendre(n-1,x) - (n-1)*legendre(n-2,x)) / n; // 遞歸,降階
}

④ C語言用遞歸方法求n階勒讓德多項式的值

剛剛做了下,比較百簡單,注意幾個容易錯飢吵含誤的地方,一是函數返回值注意是浮點型的,所以函數定義應該是float型或者double型的,不要定義成int型了,第二就是度注意遞歸公式中最後那個除以n,是多項式的和整體除以n,不要只看成最後一個因式除以n就可以了專(貌似老哥給出的遞歸公式給錯了+…+)。最爛笑後一點就是輸屬出值的時候,因為是浮點型的值輸出應該用碰敗%f型,不要用錯了就OK啦。

⑤ c語言 N階勒讓得多項式

要是給出x求出結果很容易int lerangde(int n,int x)
{
if(n==0)return 1;
else if(n == 1)return x;
else
return ((2n-1)*x-lerangde(n-1,x)-(n-1)*lerangde(n-2,x))/n ;
} 要用程序把含有x的表達式寫出來太難了,因為是迭代的,你手寫一下啊N=100,你方便些寫來么?