原题链接:蓝桥杯基础练习VIP-Sine之舞
解题思路:
现代作品
注意事项:
不支持C++11,不能愉快地to_string了...
参考代码:
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <algorithm>
#include <string>
#include <vector>
#include <memory.h>
#include <stdio.h>
using namespace std;
string getAn(int n)
{
string an;
char temp[7] = { 0 };
for (int i = 1; i <= n; i++)
{
if (i == n)
sprintf(temp, "sin(%d)", i);
else
{
if (i%2)
sprintf(temp, "sin(%d-", i);
else
sprintf(temp, "sin(%d+", i);
}
an += temp;
memset(temp, 0x00, sizeof(temp));
}
for (int i = 1; i < n; i++)
{
an += ")";
}
return an;
}
string getSn(int n)
{
string sn;
char num1[2] = { 0 }, num2[2] = { 0 };
for (int i = 1; i <= n; i++)
{
sprintf(num1, "%d", n - i + 2);
sprintf(num2, "%d", n - i + 1);
if (i == 1)
sn = "sin(1)" + string("+") + string(num2);
else
sn = "(" + sn + ")" + getAn(i) + "+" + num2;
}
return sn;
}
int main(int argc, char** argv)
{
int n = 0;
cin >> n;
cout << getSn(n) << endl;
system("pause");
return 0;
}
【思路二】
#include <cstdio>
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
string A(int i, int n)
{
string ans = "sin(";
char I = '0' + i;
if(i == n)
return ans + I + ')';
else if(i % 2 == 1)
{
return ans + I + '-' + A(i + 1, n) + ')';
}
else
{
return ans + I + '+' + A(i + 1, n) + ')';
}
}
string S(int n, int sum)
{
char Sum = '0' + sum - n;
if(n == 1)
{
return A(1,1) + '+' + Sum;
}
else
{
return '(' + S(n-1, sum) + ')' + A(1,n) + '+' + Sum;
}
}
int main(void)
{
int n;
cin >> n;
cout << S(n,n+1) << endl;
return 0;
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复