|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 liyifeng295641 于 2024-1-3 15:37 编辑
题目:
1. 请编写程序,找出斐波那契数列中数值不超过 4 百万的项,并计算这些项中值为偶数的项之和。
斐波那契数列中,从第三项开始,每一项被定义为前两项的数字之和。
从 1 和 2 开始,斐波那契数列的前 10 项应该是这样:1, 2, 3, 5, 8, 13, 21, 34, 55, 89, ...
首先,我不知道什么是斐波那契数列。我就去网上查:
来自百度:
斐波那契数列(Fibonacci sequence),又称黄金分割数列 [1],因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称“兔子数列”,其数值为:1、1、2、3、5、8、13、21、34……在数学上,这一数列以如下递推的方法定z义:F(0)=1,F(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)。
- #include <stdio.h>
-
- int fibonacci(int n) {
- if (n <= 0) {
- printf("输入错误!");
- return -1; // 返回-1表示输入有误
- } else if (n == 1 || n == 2) {
- return 1;
- } else {
- int a = 1, b = 1, c;
-
- for (int i = 3; i <= n; ++i) {
- c = a + b;
- a = b;
- b = c;
- }
-
- return b;
- }
- }
-
- int main() {
- int num;
-
- printf("请输入要求第几项斐波那契数列的值(大于等于1):");
- scanf("%d", &num);
-
- int result = fibonacci(num);
-
- if (result != -1) {
- printf("第 %d 项斐波那契数列为:%d\n", num, result);
- }
-
- return 0;
- }
复制代码
然后借鉴这个,写这个作业。
- #include <stdio.h>
- int main(){
- int a = 1, b = 1;
- long int c,sum =0;
- for(int i = 3; i <= 4000000; ++i){
- c = a + b;
- a = b;
- b = c;
- if(c % 2 == 0){
- sum += c;
- }
- }
- printf("不超过4百万的项,这些项中值为偶数的项之和:%ld", sum);
- return 0;
- }
复制代码
好的,既然你不需要使用函数来解决这个问题,那么我们可以通过循环来计算斐波那契数列,并找出满足条件的项。这里是一个不使用函数的解决方案:
- #include <stdio.h>
- int main() {
- int sum = 0;
- int fib1 = 1;
- int fib2 = 2;
- int fib_num = 0;
- while (fib_num <= 4000000) {
- if (fib_num % 2 == 0) { // 判断是否为偶数
- sum += fib_num;
- }
- fib_num = fib1 + fib2;
- fib1 = fib2;
- fib2 = fib_num;
- }
- printf("满足条件的项之和为:%d\n", sum);
- return 0;
- }
复制代码
这段代码中,我们使用 `fib1` 和 `fib2` 来保存当前的两个斐波那契数,初始化为 1 和 2。然后我们通过循环计算下一个斐波那契数 `fib_num`,并判断其是否为偶数,如果是则累加到 `sum` 中。然后更新 `fib1` 和 `fib2` 的值,继续下一轮循环。最后打印出满足条件的项之和。
希望能帮到你!
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
|
|