【蓝桥】基础vip—sine之舞

本文深入探讨了一种复杂的数学表达式的递归算法解析与代码实现过程,详细讲解了如何使用C++通过递归函数A(n)和S(n)解决特定的数学问题,输出相应的表达式Sn。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

题目

代码

思路


题目

An=sin(1–sin(2+sin(3–sin(4+...sin(n))...)
Sn=(...(A1+n)A2+n-1)A3+...+2)An+1

输入N(<201),输出相应表达式Sn

代码

#include <iostream>
using namespace std;
int i=1;
int j=0;
void A(int n)
{
    if(1==n)
    {
         cout<<"sin("<<i<<")";
         i=1;
         return;
    }
    cout<<"sin("<<i;
    if(i%2==0)cout<<"+";else cout<<"-";
    i++;
    A(n-1);
    cout<<")";
}
void S(int n)
{
    if(n==1)
    {
        //cout<<"(";
        A(1);
        cout<<"+"<<j;
        return;
    }
    cout<<"(";
    S(n-1);
    j--;
    cout<<")";
    A(n);
    cout<<"+"<<j;
}
int main()
{
    int n;
    cin>>n;
    j=n;
    S(n);
    return 0;
}

思路

递归:A(n)

                递归体:An=sin( i-A(n-1) )

                递归出口:A1=sin(n)

i是与n逆向变化的变量,当n从n变为1,i从1变成n

         S(n)

               递归体:Sn=S(n-1)*An +j (与此同时输出一队括号)(j值为1)

              递归出口  S1=A1+j(此时j值为n)(注意,最后一个S1是没有括号的!不需要输出括号了)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值