MrSix


私信TA

用户名:1658530280

访问量:153916

签 名:

等  级
排  名 16
经  验 21015
参赛次数 0
文章发表 23
年  龄 0
在职情况 学生
学  校 大连交通大学
专  业

  自我简介:

知识基础:


for(表达式1;表达式2;表达式3){若干语句}//for循环语句及其格式


思路:观察这组数据,设第一项的分子为a,分母为b,则第一项为a/b,第二项为(a+b)/a,第三项为((a+b)+a)/(a+b),第四项为(((a+b)+a))+(a+b))/((a+b)+a)......总而言之,后一项的分子为前一项分子分母的和,后一项的分母为前一项的分子


答案

#include<stdio.h>
int main(){
	double Sn=0,an=0,n,i,t,a=2.0,b=1.0;//a为分子,b为分母,an为单项和值,Sn为总和
	scanf("%lf",&n);
	Sn+=a/b;//第一项不在规律中,在循环前先加入
	for(i=1;i<n;i++){
		t=a;
		a=a+b;//将前一项的分子加分母给后一项的分子
		b=t;//将前一项的分子给后一项的分母
		an=a/b;
		Sn+=an;
	}
	printf("%0.2lf",Sn);
	return 0;
}


 

0.0分

151 人评分

  评论区

这道题不能用斐波那契数列吗?
#include <stdio.h>
int fun(int n)
{
    if(n<=3)
	return n;
    else
	return fun(n-1)+fun(n-2); 
}
int main()
{
	int N=0;
	int i=1;
	double sum=0;
	scanf("%d",&N);
	for(i=1;i<=N;i++)
	{
		i+=fun(i+1)/fun(i);
		sum=i;
	}
	printf("%.2f",sum);
	return 0;
}
2023-10-25 19:54:28
#include<stdio.h>
int main()
{
	int N,k,i;
	float d,a,b;
	a=2;
	b=1;
	d=0.0;
	scanf("%d",&N);
	for(i=1;i<=N;i++)
	{
	
		d=d+a/b;
		k=a;
		a=a+b;
		b=k;
	}
	printf("%.2f",d);
	return 0;
	
}
2023-10-25 13:23:41
#include <stdio.h>
#include <float.h>
int main(){
	int i=0,j=0,n;
	double a[1000][2],b=0,S=0;
	a[0][0]=1;
	a[0][1]=2;
	scanf("%d",&n);
	for(i=0;i<n;i++)
	{
		if(i>=1)
		{
			a[i][1]=a[i-1][1]+a[i-1][0];
			a[i][0]=a[i-1][1];
		}
		b=a[i][1]/a[i][0];
		S=S+b;
	}
	printf("%.2lf",S);
	return 0;
}
这个我感觉用二维数组来做就少了很多绕弯的地方
2023-08-09 11:03:09
感觉搞得很复杂
2023-05-27 09:41:32
我感觉n=0的时候好像不符合结果,没有加if(n==0)时,sn=0。(说的不对勿喷)
2023-03-28 20:53:31
#include<stdio.h>

int main()
{
    int N,k;
    scanf("%d",&N);
    float i,j,m,sum=0;
    i=1.0;
    j=2.0;
    for(k=1; k<=N; k++)
    {
    sum=sum+j/i;
    m=j;
    j=m+i;
    i=m;
    }
    printf("%0.2f",sum);
    return 0;
}
2023-03-13 01:06:09
这样你的第一项可不是2.0了   你输入10可不是结果把
2023-02-18 23:10:09
成功了!
#include<stdio.h>
int main()
{
    double x = 2.0;
	double y = 1.0;
	double n, i=0.0, num=0.0,t;
	scanf("%lf", &n);
	while (i < n)
	{
		num = x / y + num;
		t = x;
		x = x + y;
		y = t;
		i++;
	}
	printf("%.2lf", num);
	return 0;
}
2023-01-08 14:29:05