解题思路:
利用malloc函数动态分配内存将类似于斐波那契数列数列存储在两个动态数组内
再利用一个动态数组来接收
注意事项:
使用malloc函数最后要free()
参考代码:
/*题目 1018: [编程入门]有规律的数列求和
题目描述
有一分数序列: 2/1 3/2 5/3 8/5 13/8 21/13...... 求出这个数列的前N项之和,保留两位小数。
*/
#include<stdio.h>
#include<stdlib.h>
int main()
{
int *p1,*p2;
float *p3,sum=0;
int num,i;
scanf("%d",&num);
p1=(int *)malloc(num*(sizeof(int)));
p2=(int *)malloc(num*(sizeof(int)));
p3=(float *)malloc(num*(sizeof(float)));
p1[0]=2,p1[1]=3,p2[0]=1,p2[1]=2;
for(i=2;i<num;i++){
p1[i]=p1[i-1]+p1[i-2];
p2[i]=p2[i-1]+p2[i-2];
}
for(i=0;i<num;i++){
p3[i]=1.0*p1[i]/p2[i];
}
for(i=0;i<=num;i++){
sum+=*(p3+i);
}
printf("%.2f",sum);
free(p1);
free(p2);
free(p3);
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复