poj1953 World Cup Noise [2]

poj1953 World Cup Noise [2]


题目链接

(1)另一种方法,有问题?

/*
poj上WA

因为最近在学计算机算法分析与设计的递归与分治策略,书中有提到Fibonacci数列,我想到了Fibonacci数列的非递归方式。
但是不知道为什么,n<45时,输出和ac代码的输出是一样的,WA,下文有测试代码和输出截图。
*/

#include <stdio.h>
#include <math.h>

int
f(int n) {
    int a;

    a = 1.0 / sqrt(5.0) * (pow((1 + sqrt(5.0)) / 2, n + 2) - pow((1 - sqrt(5.0)) / 2, n + 2));

    return a;
}

int
main() {
    int n, k, i, ans;

    scanf("%d", &n);
    for( i = 1; i <= n; i++ ) {
        scanf("%d", &k);
        ans = f(k);
        printf("Scenario #%d:\n%d\n\n", i, ans);
    }

    return 0;
}

(2)测试代码


#include <stdio.h>
#include <math.h>

int
f(int n) {
    int a;

    a = 1.0 / sqrt(5.0) * (pow((1 + sqrt(5.0)) / 2, n + 2) - pow((1 - sqrt(5.0)) / 2, n + 2));

    return a;
}

int
main() {
    int i, mans;
    int ans[50] = {1, 2, 3};

    for( i = 3; i < 45; i++ ) {
        ans[i] = ans[i - 1] + ans[i - 2];
    }
    for( i = 1; i < 45; i++ ) {
        mans = f(i);
        printf("i = %d, %d =? %d\n", i, ans[i], mans);
    }

    return 0;
}

list & math

(3)难道是因为这样?

/*
我请教老师,他说让我取n = 100试一下,谢谢老师。
开始我用int直接做了,结果 n = 45 时,就溢出了。
后面我又改用long long int试了一次,发现 n = 70时,用数组打表(ac代码)和用非递归的数学公式的结果就开始不一样了。(环境:win10专业版,codeblocks16.01)
*/

(4)int测试代码

#include <stdio.h>
#include <math.h>

int
f(int n) {
    int a;

    a = 1.0 / sqrt(5.0) * (pow((1 + sqrt(5.0)) / 2, n + 2) - pow((1 - sqrt(5.0)) / 2, n + 2));

    return a;
}

int
main() {
    int i, mans;
    int ans[100] = {1, 2, 3};

    for( i = 3; i < 100; i++ ) {
        ans[i] = ans[i - 1] + ans[i - 2];
    }
    for( i = 1; i < 100; i++ ) {
        mans = f(i);
        printf("i = %d, %d =? %d\n", i, ans[i], mans);
    }

    return 0;
}

int

(5)long long int测试代码

#include <stdio.h>
#include <math.h>

long long
f(int n) {
    long long a;

    a = 1.0 / sqrt(5.0) * (pow((1 + sqrt(5.0)) / 2, n + 2) - pow((1 - sqrt(5.0)) / 2, n + 2));

    return a;
}

int
main() {
    int i;
    long long mans;
    long long ans[105] = {1, 2, 3};

    for( i = 3; i < 100; i++ ) {
        ans[i] = ans[i - 1] + ans[i - 2];
    }
    for( i = 1; i < 100; i++ ) {
        mans = f(i);
        printf("i = %d, %I64d =? %I64d\n", i, ans[i], mans);
    }

    return 0;
}

long long int

(6)可是题目是这样说的

/*
The first line contains the number of scenarios.
For each scenario, you are given a single positive integer less than 45 on a line by itself.

不是说好less than 45的吗?
*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值