蓝桥杯 一个大数边界引发的血案

坑题,输入一个不超过18446744073709551615的正整数a,输出a+2。

18446744073709551615是unsigned long long 可取的最大值,因此可以特判一下,定义一个unsigned long long类型的a,若输入的a=18446744073709551614 输出18446744073709551616,否则如果a=18446744073709551615,输出18446744073709551617,否则以%llu形式输出a+2;

#include<stdio.h>
int main()
{
    unsigned long long n;
    scanf("%llu",&n);   //无符号长整型 输入格式 %llu 
    if(n==18446744073709551615)
        printf("18446744073709551617\n");
    else if(n==18446744073709551614)
        printf("18446744073709551616\n");
    else
        printf("%llu\n",n+2);
    return 0;
}
 这可能是最隆重的边界判断了
posted @ 2019-10-28 07:42  AmosAlbert  阅读(163)  评论(0)    收藏  举报