鱼C论坛

 找回密码
 立即注册
查看: 763|回复: 1

C++递归与非递归

[复制链接]
发表于 2023-11-23 20:17:42 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
实现计算图片上的n阶勒让德多项式的值
我用的不是递归方法,想请教一下是否有误,其次想问一下用递归算法怎么写代码
  1. #include <iostream>
  2. using namespace std;

  3. float p(float a,float b,float n,float x)
  4. {
  5.         float c;
  6.         c=((2*n-1)*x*b-(n-1)*a)/n;
  7.         return c;
  8. }

  9. void main()
  10. {
  11.         float x,n,h,p1,p2,p3;
  12.         cout<<"x=";
  13.         cin>>x;
  14.         cout<<"n=";
  15.         cin>>n;
  16.         p1=1;
  17.         p2=x;
  18.         if (n==0)
  19.                 cout<<"当x="<<x<<"时的"<<n<<"阶多项式的值为"<<1<<endl;
  20.         if (n==1)
  21.         {
  22.                 cout<<"当x="<<x<<"时的"<<n<<"阶多项式的值为"<<x<<endl;
  23.         }
  24.         if (n>1)
  25.         {
  26.                 for (h=2;h<n+1;h++)
  27.                 {
  28.                         p3=p(p1,p2,h,x);
  29.                         p1=p2;
  30.                         p2=p3;
  31.                 }
  32.                 cout<<"当x="<<x<<"时的"<<n<<"阶多项式的值为"<<p3<<endl;
  33.         }
  34.         system("pause");
  35. }
复制代码
图片1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-23 20:18:56 | 显示全部楼层
你的非递归实现代码有一些问题。首先,在没有输入变量a和b的情况下,你计算的c值是不正确的。其次,你在main函数中定义了一些变量(如x、n、h等),但没有给它们赋初值。最后,main函数需要返回一个整型值,而不是void。

下面是修复了这些问题的代码:
  1. #include <iostream>
  2. using namespace std;
  3. float p(float a, float b, float n, float x)
  4. {
  5.     float c;
  6.     c = ((2 * n - 1) * x * b - (n - 1) * a) / n;
  7.     return c;
  8. }
  9. int main()
  10. {
  11.     float a = 0, b = 1; // 给a和b赋初值,这里假设a=0,b=1
  12.     float x, n;
  13.    
  14.     cout << "请输入x的值:";
  15.     cin >> x;
  16.     cout << "请输入n的值:";
  17.     cin >> n;
  18.     float p1 = 1;
  19.     float p2 = x;
  20.    
  21.     for (int i = 3; i <= n; i++)
  22.     {
  23.         float p3 = p1;
  24.         p1 = p2;
  25.         p2 = p(p3, p2, i, x);
  26.     }
  27.    
  28.     cout << "n阶勒让德多项式的值为:" << p2 << endl;
  29.     return 0;
  30. }
复制代码

对于递归方法,勒让德多项式的递归定义如下:

P0(x) = 1
P1(x) = x
Pn(x) = ((2n-1)xPn-1(x) - (n-1)Pn-2(x))/n

下面是用递归方法实现计算勒让德多项式的代码:
  1. #include <iostream>
  2. using namespace std;
  3. float p(float x, int n)
  4. {
  5.     if (n == 0)
  6.         return 1;
  7.     else if (n == 1)
  8.         return x;
  9.     else
  10.         return ((2 * n - 1) * x * p(x, n - 1) - (n - 1) * p(x, n - 2)) / n;
  11. }
  12. int main()
  13. {
  14.     float x;
  15.     int n;
  16.    
  17.     cout << "请输入x的值:";
  18.     cin >> x;
  19.     cout << "请输入n的值:";
  20.     cin >> n;
  21.    
  22.     float result = p(x, n);
  23.    
  24.     cout << "n阶勒让德多项式的值为:" << result << endl;
  25.     return 0;
  26. }
复制代码

这个递归方法比较简洁,但在计算过程中会产生大量的重复计算,效率较低。所以在实际应用中,推荐使用非递归方法实现。
以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 0 反对 1

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-18 00:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表