《啊哈C语言》这本书上的练习题:
从键盘任意读入四个整数,让计算机从中找出最大的一个。
#include <stdio.h>
#include <stdlib.h>
/* 从四个整数中找出最大的数 */
int main()
{
int a, b, c, d, e;
printf("请输入四个整数:\n");
scanf("%d %d %d %d", &a, &b, &c, &d);
if (a > b) e = a;
else e = b;
if (c > e) e = c;
if (d > e) e = d;
printf("四个整数中最大的数是%d\n");
system("pause");
return 0;
}
这种方法其实就是冒泡排序,临近的两个数先比大小,胜出的赋值给变量e;然后再和第三个数比较,较大的赋值给变量e;再和第四个数比较,较大的赋值给变量e;最后输出变量e的值。
但是这个方法有个问题,如果输入的整数有很大的值,比如十位以上的数字,那么输出结果就不对。
是数据类型的问题吗?换成long试试
是不是声明变量的时候给变量定义的是int类型呢?换成长整型long是不是可以呢?
#include <stdio.h>
#include <stdlib.h>
/* 从四个整数中找出最大的数 */
int main()
{
long a, b, c, d, e;
printf("请输入四个整数:\n");
scanf("%d %d %d %d", &a, &b, &c, &d);
if (a > b) e = a;
else e = b;
if (c > e) e = c;
if (d > e) e = d;
printf("四个整数中最大的数是%d\n");
system("pause");
return 0;
}
把int类型换成long类型之后还是一样的,数字太大结果就不对了,比如输入一个上百亿的数字就识别不了,程序不理它。
看看int和long需要的存储大小
那么我们看下int类型存储大小为2或4个字节,值的范围是-32,768~32,767或者是 -2,147,483,648 ~ 2,147,483,647。我试了一下定义int类型的程序,输入2,147,483,647这个值,可以识别。那么这个机器(win 64)上int类型存储大小是4个字节。long类型呢,存储大小也是4个字节,值的范围是-2,147,483,648 ~ 2,147,483,647。如果是Linux系统的x86_64系统,那么long类型的存储大小就是8个字节了,还没有验证过。