MrSix


私信TA

用户名:1658530280

访问量:153896

签 名:

等  级
排  名 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 人评分

  评论区

为什么for循环里还要写b=t,直接an=a/t不行么
2022-12-12 15:00:03
#include<stdio.h>
float Up(float x)
{
    if (x <= 2)
        return 1;
    else
        return Up(x - 1) + Up(x - 2);
}
int main()
{
    int n;
    float sum=0;
    scanf("%d", &n);
    for (float i = 1; i <= n; i++)
    {
        sum += Up(i+2) / Up(i+1);
    }
    printf("%.2f", sum);
}
2022-11-29 15:27:59
#include<stdio.h>

//有一分数序列: 2/1 3/2 5/3 8/5 13/8 21/13...... 求出这个数列的前N项之和,保留两位小数
int main()
{
    int N, i , m = 1, z = 2, t;
    float sum = 0.0;
    scanf("%d", &N);
    
    for (i = 1; i <= N; i++)
    {
        sum += 1.0*z/m;
        t = z;
        z += m;
        m = t;
    }
    
    printf("%.2f\n", sum);
    return 0;
}
2022-10-26 15:16:21
#include<stdio.h>
float Sum(int num);
int main()
{
	int num = 0;
	float a = 0;
	scanf("%d", &num);
	a=Sum(num);
	printf("%.2f", a);
	return;
}
float Sum(int num)//求前N项和
{
	int a[5] = { [0] = 1,0,0 };
	float b[5] = { [0] = 2,0,0 };
	int k=1, j=0;
	float sum = 2;

	for (int i = 1; i < num; i++)
	{
		
		if (k == 4) k = 1;//循环到四的时候,从a1开始重置,a4=a1=b3;b4=b1=a3+b3;
		if (j == 4) j = 1;//循环到四的时候,前面的值舍弃,a5=a2=b1;b5=b2=b1+a1;
		a[k] = b[j];
		b[k] = a[j] + b[j];
		sum = sum + b[k]/ a[k];
		k++;
		j++;
	}
	return sum;
}
这个为什么一直显示::运行错误:运行时错误,非法的内存访问,数组越界,指针漂移,调用禁用的系统函数。
求大佬帮忙看看吧
2022-09-25 19:36:20
N=0时呢
2022-08-07 17:25:19
#include <stdio.h>

int main(void)
{
    int num;
    scanf("%d",&num);
    int data[num + 1];
    /*斐波拉契数列*/
    data[0] = 1;
    data[1] = 2; 
    for(int i = 2;i <= num;i++)
    {
        data[i] = data[i - 1] + data[i - 2]; 

    }
    float res = 0;
    for(int i = num; i > 0;i--)
    {
        res += (float)data[i] / data[i - 1];
    }
    printf("%.2f\n" ,res);
    return 0;
}
2022-05-24 23:20:43
#include<stdio.h>
int main()
{
    int a,N;
    double b=1,c=2,d,s=0;
    scanf("%d",&N);
    for(a=1;a<=N;a++)
    {
        s+=c/b;
        d=c;
        c+=b;
        b=d;
    }
    printf("%.2lf",s);
    return 0;
}
2022-02-16 17:47:55
#include<stdio.h>
int n;
      	scanf("%d",&n);
      	float x=2,y=1;
      	float tal=0;
      	int i;
      	for(i=1;i<=n;i++)
      	{
      	    tal+=x/y;
      	    float t=x+y;
      	    y=x;
      	    x=t;
		  }
		  printf("%.2f",tal);
2022-01-24 21:41:30