知识基础:


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分

164 人评分

  评论区

#include<stdio.h>
int main()
{
    int i,n;
    scanf("%d",&n);
    float j[100],sum=0;
    j[0]=1;
    j[1]=2;
    j[2]=3;
    for(i=2;i<n+1;i++)
    {
    	j[i]=j[i-1]+j[i-2];
    }
    for(i=0;i<n+1;i++)
    {
    	printf("%3.2f ",j[i]);
    }
    for(i=0;i<n;i++)
    {
    	sum=sum+j[i+1]/j[i];
    }
    printf("\n%3.2f",sum);
    return 0;
}
2023-11-22 17:32:51
//有一分数序列:2/1  3/2  5/3  8/5  13/8  21/13......求出这个数列的前N项之和,保留两位小数。
//规律分析:分子 2 3 5 8 13 21... 分母 1 2 3 5 8 13 21....。后一个数的分母是前一个数的分子,后一个数的分子是前一个数的分子+分母
int main()
{
	int a;
	float sum = 0.0;
	scanf("%d", &a);
	float y = 1.0;//分母初始值为1
	float x = 2.0;//分子初始值为2
	for (int i = 1; i <= a; i++)//循环a次
	{
		int z = 0;
		sum = sum + x/y;//注意:x,y若为int类型 x/y 计算结果为整形不能得到小数
		z = y;
		y = x;//后一个数的分母为前一个数的分子
		x = x + z;//后一个数的分子等于前一个数的分子+分母
	}
	printf("%.2f", sum);
	return 0;
}
2023-11-21 17:51:34
#include<stdio.h>
int main(){
    double sum,d,a,b,c,N;
    a=2.00;
    b=1.00;
    c=1.00;
    sum=2.00;
    scanf("%lf",&N);
    while(c<=N)
    {
        c++;
        a=a+b;
        b=a-b;
        d=a/b;
        sum=sum+d;
    }
    printf("%.2f",sum);
    return 0;
}
大家能帮忙看看我这个哪里错了
2023-11-09 09:07:34
这道题不能用斐波那契数列吗?
#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