java用递归算法求 1-2+3-4+5-6......+ 10
2个回答
展开全部
思路:先用递归求出一个数的阶乘,接着for循环累加求和。参考代码:<pre t="code" l="cpp">#include<stdio.h>
int fun(int n){
if(n==1) return 1;//递归结束条件
return n*fun(n-1);//递归式
}
int main()
{
int sum=0,i;
for(i=1;i<=6;i++)//for循环累加求和
sum+=fun(i);
printf("%d\n",sum);
return 0;
}
/*
运行结果:
873
*/
int fun(int n){
if(n==1) return 1;//递归结束条件
return n*fun(n-1);//递归式
}
int main()
{
int sum=0,i;
for(i=1;i<=6;i++)//for循环累加求和
sum+=fun(i);
printf("%d\n",sum);
return 0;
}
/*
运行结果:
873
*/
展开全部
//花了几分钟就写出来了,哈哈,代码很简单,就不写注释了,有疑问,再问
public class DiGui {
public static void main(String args[]){
int n = 3;
int rst = getResult(n);
System.out.println(n+"的执行结果:"+rst);
}
public static int getResult(int n){
int result = 0;
for(int i=1;i<=n;i++){
switch(i%2){
case 0:result -=i;
break;
case 1: result += i;
break;
}
}
return result;
}
}
public class DiGui {
public static void main(String args[]){
int n = 3;
int rst = getResult(n);
System.out.println(n+"的执行结果:"+rst);
}
public static int getResult(int n){
int result = 0;
for(int i=1;i<=n;i++){
switch(i%2){
case 0:result -=i;
break;
case 1: result += i;
break;
}
}
return result;
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询