蓝桥杯 基础练习 Sine之舞 (vip)递归 两种方法

版权声明:(整理不易,如本文对您有益,请为我点赞吧!)本文为博主原创文章,转载请附上博文链接! https://blog.csdn.net/Qi2456/article/details/88117911

 基础练习 Sine之舞

(Sn的计算方法不同)

方法一:

#include<bits/stdc++.h>
using namespace std;
void an(int i,int n)
{
    if(i==n)
    {
        cout<<"sin(";
        cout<<n;
        cout<<")";
    }
    else
    {
        cout<<"sin(";
        cout<<i;
        if(i<n)
        {

            if(i%2==1)
                cout<<"-";
            else
                cout<<"+";
        }
        an(i+1,n);
        cout<<")";

    }
}

void sn(int i,int n)
{
   if(i==1)
   {
       an(1,i);
       cout<<"+";
       cout<<n;
   }
   else
   {
       cout<<"(";
       sn(i-1,n);
       cout<<")";
       an(1,i);
       cout<<"+";
       cout<<n-i+1;
   }

}

int main()
{
    int n;
    cin>>n;
    sn(n,n);
    return 0;
}

方法二:

#include<bits/stdc++.h>
using namespace std;
void an(int i,int n)
{
    if(i==n)
    {
        cout<<"sin(";
        cout<<n;
        cout<<")";
    }
    else
    {
        cout<<"sin(";
        cout<<i;
        if(i<n)
        {

            if(i%2==1)
                cout<<"-";
            else
                cout<<"+";
        }
        an(i+1,n);
        cout<<")";

    }
}

void sn(int i,int n)
{
    if(i==n)
    {
        an(1,i);
        cout<<"+1";
    }
    else
    {
        an(1,i);
        cout<<"+";
        cout<<n-i+1;
        cout<<")";
         sn(i+1,n);
    }

}

int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n-1;i++)
    {
        cout<<"(";
    }
    sn(1,n);
    return 0;
}

猜你喜欢

转载自blog.csdn.net/Qi2456/article/details/88117911
今日推荐