【JAVA】(vip)蓝桥杯试题 基础练习 Sine之舞 BASIC-21 JAVA
试题 基础练习 Sine之舞
资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
最近FJ为他的奶牛们开设了数学分析课,FJ知道若要学好这门课,必须有一个好的三角函数基本功。所以他准备和奶牛们做一个“Sine之舞”的游戏,寓教于乐,提高奶牛们的计算能力。
不妨设
An=sin(1–sin(2+sin(3–sin(4+…sin(n))…)
Sn=(…(A1+n)A2+n-1)A3+…+2)An+1
FJ想让奶牛们计算Sn的值,请你帮助FJ打印出Sn的完整表达式,以方便奶牛们做题。
输入格式
仅有一个数:N<201。
输出格式
请输出相应的表达式Sn,以一个换行符结束。输出中不得含有多余的空格或换行、回车符。
样例输入
3
样例输出
((sin(1)+3)sin(1–sin(2))+2)sin(1–sin(2+sin(3)))+1
额外知识
如何减少Java方法的参数?如何让Java 方法支持默认的参数值?
-
方法一:通过方法的重载来间接地减少参数个数,通过方法的重载间接地支持默认的参数值,
//递归An1 //通过方法的重载 //1.将An1的参数由两个变成一个 //2.使An1支持默认的参数值 public static String An1(int n) { return An1(n, 1); } //递归An 索引i从小到大 以i记录当前递归的位置 public static String An1(int n, int i) { //。。。。 }
-
方法二:使用工厂模式。当方法的参数太多时,方法的重载这种方法就不适合了
思路一:递推
递推对应An和Sn
思路二:递归
递归对应An1和Sn1
思路二的要点:
-
递归需要设置一个索引,表示递归的位置,本代码里以i表示,i从大到小还是从小到大很重要,
//递归An 索引i从小到大 以i记录当前递归的位置 public static String An1(int n, int i) {
//递归Sn 索引i从大到小 以i记录当前递归的位置 public static String Sn1(int n, int i) {
本题代码:
我将递推和递归写到了一个java文件里,你们可以自己搭配,一共四种方法,An+Sn(递推+递推),An+Sn1(递推+递归),An1+Sn(递归+递推),An1+Sn1(递归加递归)
import java.util.Scanner;
public class DanceOfSine2 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
sc.close();
System.out.println(Sn(n));
//或 输出Sn1 System.out.println(Sn1(n));
/*检验代码
for (int i = 1; i < 10; i++) {
System.out.println(An(i));
System.out.println(An1(i));
}
for (int i = 1; i < 10; i++) {
System.out.println(Sn(i));
System.out.println(Sn1(i));
}*/
}
//递推An
public static String An(int n) {
StringBuilder str = new StringBuilder();
for (int i = 1; i <= n; i++) {
str.append("sin(").append(i);
if (i % 2 == 1 && i != n) {
str.append("-");
} else if (i % 2 == 0 && i != n) {
str.append("+");
}
}
for (int i = 1; i <= n; i++) {
str.append(")");
}
return str.toString();
}
//递归An1
//通过方法的重载
//1.将An1的参数由两个变成一个
//2.使An1支持默认的参数值
public static String An1(int n) {
return An1(n, 1);
}
//递归An 索引i从小到大 以i记录当前递归的位置
public static String An1(int n, int i) {
if (i == n) {
return "sin(" + i + ")";
}
String operater = "-";
if (i % 2 == 0) {
operater = "+";
}
return "sin(" + i + operater + An1(n, i + 1) + ")";
}
//递推Sn
public static String Sn(int n) {
StringBuilder str = new StringBuilder();
for (int i = 1; i < n; i++) {
str.append("(");
}
for (int i = 1; i <= n; i++) {
if (i != n) {
str.append(An(i)).append("+").append(n - i + 1).append(")");
} else {
str.append(An(i)).append("+").append(n - i + 1);
}
}
return str.toString();
}
//递归Sn
//通过方法的重载
//1.将Sn1的参数由两个变成一个
//2.使Sn1支持默认的参数值
public static String Sn1(int n) {
return Sn1(n, n);
}
//递归Sn 索引i从大到小 以i记录当前递归的位置
public static String Sn1(int n, int i) {
if (i == 1) {
return An1(1) + "+" + n;
}
return "(" + Sn1(n, i - 1) + ")" + An1(i) + "+" + (n - i + 1);
}
/*//递归Sn 索引i从小到大 有很大的问题
public static String Sn1(int n) {
return Sn1(n, 1);
}
//递归Sn 索引i从小到大 有很大的问题
public static String Sn1(int n, int i) {
if (i == n) {
return An1(n) + "+" + 1;
}
return "(" + An1(i) + "+" + (n - i + 1) + ")" + Sn1(n, i + 1);
}*/
}
大家好,我是[爱做梦的子浩](https://blog.csdn.net/weixin_43124279),我是东北大学大数据实验班大三的小菜鸡,非常向往优秀,羡慕优秀的人,已拿两个暑假offer,欢迎大家找我进行交流😂😂😂
这是我的博客地址:[子浩的博客https://blog.csdn.net/weixin_43124279]
——
版权声明:本文为CSDN博主「爱做梦的子浩」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。