求前n项和c语言
⑴ c语言如何用数组求Fibonacci数列的前N项和
#include<stdio.h>
int main()
{
int i,f[21]={1,1};//对最前面两个元素f[0]和f[1]赋初值1
for(i=2;i<21;i++)
{
f<i>=f[i-2]+f[i-1];//先后求出f[2]~f[20]的值
}
for(i=0;i<21;i++)
{
if(i%5==0)//控制每输出5个数后换行
{
printf(" ");
}
printf("%d ",f<i>);//输出一个数
}
printf(" ");
return 0;
}
(1)求前n项和c语言扩展阅读:
printf()函数的调用格式为:printf("<格式化字符串>",<参量表>)。
其中格式化字符串包括两部分内容:一部分是正常字符,这些字符将按原样输出;另一部分是格式化规定字符,以"%"开始,后跟一个或几个规定字符,用来确定输出内容格式。
参量表是需要输出的一系列参数,其个数必须与格式化字符串所说明的输出参数个数一样多,各参数之间用","分开,且顺序一一对应,否则将会出现意想不到的错误。
比如:
int a=1234;
printf("a=%d ",a);
输出结果为a=1234。
scanf()是C语言中的一个输入函数。与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include<stdio.h>。
int scanf(const char*restrict format,...);
函数scanf()是从标准输入流stdin(标准输入设备,一般指向键盘)中读内容的通用子程序,可以说明的格式读入多个字符,并保存在对应地址的变量中。
如:
scanf("%d%d",&a,&b);
函数返回值为int型,如果a和b都被成功读入,那么scanf的返回值就是2。
⑵ C语言求前n项和,不知道哪里错了
经鉴定,LZ对于C语言中的数组/指针以及函数的相关知识点还没掌握好
这一题的正确思路应该是,设计一个函数int feibo(int n),该函数的作用是返回斐波那契数列第n项的值。主函数中获取用户输入的N,然后一个循环输出斐波那契的前N项
如果需要的话请追问,我可以根据我给你的思路提供相关代码供你参考
⑶ c语言求数列前n项和
main(){
int i,n,s=1,f[]={0,1,1};
printf("Please input the number of terms:");
scanf("%d",&n);
if(n==0){s=0;f[2]=0;}
for (i=2;i<=n;i++)
{ f[2]=f[1]+f[0];f[0]=f[1];f[1]=f[2];
s+=f[1];
}
printf("f(%i)=%i\n",n,f[2]);
printf("Sum(%i)=%i\n",n,s);
scanf("%d");
}
⑷ C语言:求5/6+11/12+19/20+29/30+...的前N项的和,咋写
分析:
1) 定义变量n,scanf("%d",&n); if ( n<0 || n>99999 ) { printf("输入错误。 "); break; }
2)定义double类型累加和变量s,因为多项式中有分式,因此需要浮点类型变量保存结果
printf("%.6lf ",s); 由于需要多次求不同n值的和,因此每次求和之前需要强制清0
3)多组测试,用循环结构,由于不关心循环次数,选用while循环:
while ( 1 ) { ...; if ( n==0 ) break; }
4)分析多项式:一般多项式求和采用for循环,利用循环变量i的取值计算相关多项式分子和分母
每项分子和分母都是整型数据,因此可以分别用整型变量求,分子fz,分母fm
分子规律是当前分母取值减1,分母规律i=0,1,2,3,...,n时取值2x3,3x4,4x5,...,(i+2)x(i+3)
注意,直接用整数相除需要将分子或分母中至少一个强制数据类型转换成浮点数,否则只能得到整型结果。
因此程序为:
#include<stdio.h>
void main() { int n,i,fz,fm; double s;
while ( 1 ) { //无限循环,退出由循环体中条件语句完成
printf("请输入N(1~99999):"); scanf("%d",&n); if ( n==0 ) break;
if ( n<0 || n>99999 ) { printf("输入错误。 "); break; }
s=0; for ( i=0;i<n;i++ ) { fm=(i+2)*(i+3); fz=fm-1; s+=(double)fz/fm; }
printf("%.6lf ",s);
}
printf("程序结束运行。 ");
}
⑸ C语言 求多次运算前N项的和。
#include<stdio.h>
void main(void)
{
int i1=0,i2=0;
printf("输入次数: ");
scanf("%d",&i1);
for(int i=1;i<=i1;i++)
{
scanf("%d",&i2);
int sum1=0;
for(int j=1;j<=i2;j++)
{sum1+=j;
}
printf("%d\n",sum1);
}
}
差不多就这样吧,DOS下输入是有缓冲区的,可以达到目的,windows下可能还要调调;
⑹ C语言 求多次运算前N项的和。
#include<stdio.h>
#include<stdlib.h>
intmain()
{
intcount;
intnum;
printf("输入运算次数:");
scanf("%d",&count);
for(inti=0;i<count;i++)
{
printf("输入第%d个运算的项数:",i+1);
scanf("%d",&num);
printf("前%d项和为:%d ",num,(num*(num+1))/2);
}
system("pause");
return0;
}
⑺ C语言编程 求序列前N项和
2/1+3/2+5/3+8/5+...这个数列每项的分子、分母分别是Fibonacci数列的后一项与前一项。求这一数列前N项的和可采取N由键盘输入,设一循环按Fibonacci数列规律求出分子与分母,将将分式转换为浮点除法求值累加获得最后结果。举例代码如下:
#include"stdio.h"
intmain(intargc,char*argv[]){
inta,b,i,N;
doubles;
printf("InputN(int0<N<44)... N=");//大于43时int范围溢出
if(scanf("%d",&N)!=1||N<1||N>43){//保证输入正确
printf("Inputerror,exit... ");
return0;
}
for(s=0.0,a=2,b=i=1;i<=N;i++){//由此循环计算
s+=a/(b+0.0);//当前项累加给s
a+=b;//下一项的分子是当前项分子分母之和
b=a-b;//下一项分母是当前项分子
}
printf("Theresultare%.2f(whenN=%d) ",s,N);
return0;
}
试运行结果如下图:
⑻ C语言,输入n,计算前n项和
#include<stdio.h>
intmain()
{
inti,n;
inta1,b1,a2,b2,ai,bi;
floatsum,t=1.0;
a1=2,b1=1;
a2=3,b2=2;
sum=t*a1/b1+t*a2/b2;
scanf("%d",&n);
for(i=2;i<n;i++)//从第3项开始
{
ai=a1+a2;
bi=b1+b2;
sum+=t*ai/bi;
a1=a2,b1=b2;
a2=ai,b2=bi;
}
printf("前%d项和=%f ",n,sum);
return0;
}
示例运行结果:
2
前2项和=3.500000
3
前3项和=5.166667
10
前10项和=16.479906
⑼ C语言求前n项和,不知道哪里错了
经鉴定,LZ对于C语言中的数组/指针以及函数的相关知识点还没掌握好
这一题的正确思路应该是,设计一个函数int
feibo(int
n),该函数的作用是返回
斐波那契
数列第n项的值。主函数中获取用户输入的N,然后一个循环输出斐波那契的前N项
如果需要的话请追问,我可以根据我给你的思路提供相关代码供你参考