dhy328 2015-12-10 06:50 采纳率: 0%
浏览 8949

c语言整数超出unsigned long long的表示范围该怎么办

#define _CRT_SECURE_NO_DEPRECATE
#include<stdio.h>
#include<limits.h>

unsigned long long number(int n);
int main(void)
{
    int num;

    printf("你要计算第几个数? (q to quit):\n");
    while (scanf("%d", &num) == 1)
    {
        if (num < 0)
            printf("无效的数字\n");
        else
        {
            printf("第%d 个数是%llu\n", num, number(num));
        }
        printf(" 输入一个0-100的整数 (q to quit):\n ");
        printf("可以表示的最大的数为%llu\n", ULLONG_MAX);
    }
    return 0;
}
unsigned long long number(int n)
{
    unsigned  long long x1 = 0, x2 = 1, xn = 0;
    if (n < 3)
        xn = 1;
    else
        for (int i = 2; i <= n; ++i)
        { 
            xn = x1 + x2;
            x1 = x2;
            x2 = xn;
        }
        return xn;
}

上面的程序计算斐波那契数列的第97项时就已经溢出了,如果要求第100项、第10000项。。。。。该怎么办?

  • 写回答

3条回答 默认 最新

  • 云霏阳 2015-12-10 09:12
    关注

    1.在64位系统上,unsigned long long是8个字节,和unsigned long 一样;
    2.如果unsigned long long溢出了,可以这么处理,起始就是自己实现16字节的整数,如果还不够,类似方法实现24,32字节整数:
    unsigned long long high;
    unsigned long long low;
    low表示底8字节,high表示高8字节,如果low溢出了,就high ++

    评论

报告相同问题?

悬赏问题

  • ¥30 dspbuilder中使用signalcompiler时报错Error during compilation: Fitter failed,求解决办法
  • ¥15 gwas 分析-数据质控之过滤稀有突变中出现的问题
  • ¥15 没有注册类 (异常来自 HRESULT: 0x80040154 (REGDB_E_CLASSNOTREG))
  • ¥15 知识蒸馏实战博客问题
  • ¥15 用PLC设计纸袋糊底机送料系统
  • ¥15 simulink仿真中dtc控制永磁同步电机如何控制开关频率
  • ¥15 用C语言输入方程怎么
  • ¥15 网站显示不安全连接问题
  • ¥15 51单片机显示器问题
  • ¥20 关于#qt#的问题:Qt代码的移植问题