Dev-C++下关于几种int类型格式符的实验
2005-03-10 21:46
549 查看
kingwei 2005.3.10
实验环境: Dev-C++ 4.9.6.0 (gcc/mingw32), 使用-Wall编译选项
#include <stdio.h>
int main()
{
int v_int;
signed int v_signed_int;
unsigned int v_unsigned_int;
signed short int v_signed_short_int;
unsigned short int v_unsigned_short_int;
signed long int v_signed_long_int;
unsigned long int v_unsigned_long_int;
freopen("intuex.txt", "r", stdin);
freopen("out.txt", "w", stdout);
/* [-2^31, 2^31-1] ==> [-2147483648, 2147483647] */
scanf("%d", &v_int);
printf("%d/n", v_int);
/* [-2^31, 2^31-1] ==> [-2147483648, 2147483647] */
scanf("%d", &v_signed_int);
printf("%d/n", v_signed_int);
/* [0, 2^32-1] ==> [0, 4294967295] */
scanf("%u", &v_unsigned_int);
printf("%u/n", v_unsigned_int);
/* [-2^15, 2^15-1] ==> [-32768, 32767] */
scanf("%hd", &v_signed_short_int);
printf("%hd/n", v_signed_short_int);
/* [0, 2^32-1] ==> [0, 65535] */
scanf("%hu", &v_unsigned_short_int);
printf("%hu/n", v_unsigned_short_int);
/* [-2^31, 2^31-1] ==> [-2147483648, 2147483647] */
scanf("%ld", &v_signed_long_int);
printf("%ld/n", v_signed_long_int);
/* [0, 2^32-1] ==> [0, 4294967295] */
scanf("%lu", &v_unsigned_long_int);
printf("%lu/n", v_unsigned_long_int);
return 0;
}
测试样例及输出:
----- test case #1: 下界 -----
-2147483648
-2147483648
0
-32768
0
-2147483648
0
output:
-2147483648
-2147483648
0
-32768
0
-2147483648
0
----- test case #2: 上界 -----
2147483647
2147483647
4294967295
32767
65535
2147483647
4294967295
output:
2147483647
2147483647
4294967295
32767
65535
2147483647
4294967295
----- test case #3: 下溢 -----
-2147483649
-2147483649
-1
-32769
-1
-2147483649
-1
output:
2147483647
2147483647
4294967295
32767
65535
2147483647
4294967295
----- test case #4: 上溢 -----
2147483648
2147483648
4294967296
32768
65536
2147483648
4294967296
output:
-2147483648
-2147483648
0
-32768
0
-2147483648
0
可以看到,输入数据下溢,成为该类型所能表示范围的上界;输入数据上溢,成为该类型所能表示范围的下界.
实验环境: Dev-C++ 4.9.6.0 (gcc/mingw32), 使用-Wall编译选项
#include <stdio.h>
int main()
{
int v_int;
signed int v_signed_int;
unsigned int v_unsigned_int;
signed short int v_signed_short_int;
unsigned short int v_unsigned_short_int;
signed long int v_signed_long_int;
unsigned long int v_unsigned_long_int;
freopen("intuex.txt", "r", stdin);
freopen("out.txt", "w", stdout);
/* [-2^31, 2^31-1] ==> [-2147483648, 2147483647] */
scanf("%d", &v_int);
printf("%d/n", v_int);
/* [-2^31, 2^31-1] ==> [-2147483648, 2147483647] */
scanf("%d", &v_signed_int);
printf("%d/n", v_signed_int);
/* [0, 2^32-1] ==> [0, 4294967295] */
scanf("%u", &v_unsigned_int);
printf("%u/n", v_unsigned_int);
/* [-2^15, 2^15-1] ==> [-32768, 32767] */
scanf("%hd", &v_signed_short_int);
printf("%hd/n", v_signed_short_int);
/* [0, 2^32-1] ==> [0, 65535] */
scanf("%hu", &v_unsigned_short_int);
printf("%hu/n", v_unsigned_short_int);
/* [-2^31, 2^31-1] ==> [-2147483648, 2147483647] */
scanf("%ld", &v_signed_long_int);
printf("%ld/n", v_signed_long_int);
/* [0, 2^32-1] ==> [0, 4294967295] */
scanf("%lu", &v_unsigned_long_int);
printf("%lu/n", v_unsigned_long_int);
return 0;
}
测试样例及输出:
----- test case #1: 下界 -----
-2147483648
-2147483648
0
-32768
0
-2147483648
0
output:
-2147483648
-2147483648
0
-32768
0
-2147483648
0
----- test case #2: 上界 -----
2147483647
2147483647
4294967295
32767
65535
2147483647
4294967295
output:
2147483647
2147483647
4294967295
32767
65535
2147483647
4294967295
----- test case #3: 下溢 -----
-2147483649
-2147483649
-1
-32769
-1
-2147483649
-1
output:
2147483647
2147483647
4294967295
32767
65535
2147483647
4294967295
----- test case #4: 上溢 -----
2147483648
2147483648
4294967296
32768
65536
2147483648
4294967296
output:
-2147483648
-2147483648
0
-32768
0
-2147483648
0
可以看到,输入数据下溢,成为该类型所能表示范围的上界;输入数据上溢,成为该类型所能表示范围的下界.
相关文章推荐
- Dev-C++下关于float/double类型的实验
- Dev-C++下关于long long类型的实验
- Dev-C++下关于char类型的实验
- C++中将string类型转换为int, float, double类型 主要通过以下几种方式:
- 关于C和C++中的基本数据类型int、long、long long、float、double、char、string的大小及表示范围
- C++中将string类型转换为int, float, double类型 主要通过以下几种方式:
- C++中将string类型转换为int, float, double类型 主要通过以下几种方式:
- C++中将string类型转换为int, float, double类型 主要通过以下几种方式:
- 《C++第十五周实验报告3-1、2》---对照运行的结果和教材中关于格式控制的说明
- 一个关于c/c++语言内存数据类型的实验
- 关于C++中string对象向int、float、double类型的转换的方法汇总
- 关于C++多线程程序中简单类型(int/bool)的安全性
- 关于C和C++中的基本数据类型int、long、long long、float、double、char、string的大小及表示范围
- MFC中遇到的关于error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int
- C++中将string类型转换为int, float, double类型 主要通过以下几种方式:
- C++中将string类型转换为int, float, double类型 主要通过以下几种方式:
- C++中将string类型转换为int, float, double类型 主要通过以下几种方式:
- C++里的int 和string类型相互转换
- C++:关于int *a; int &a; int & *a; int * &a
- C++中的基本类型及输入输出格式