C/C++语言中,表示整数和浮点数有好多种数据类型。在32位平台中,每种类型在内存中占用的字节数各不相同:
char: 1 Byte
int: 4 Byte
long: 4 Byte
long long: 8 Byte
__int128: 16 Byte (前面两个下划线’_’,此类型仅在C++支持,但不影响本题求解)
float: 4 Byte
double: 8 Byte
long double: 16 Byte
一个字节对应8位二进制数,这也决定了他们能表达数值的范围是有差异的。现在给你一些数据类型的查询,请输出其对应的字节数。
建议大家使用函数进行模块化编程,例如:
int getByteofType(char t[])
{
}
int main()
{
}
输入格式:
第一行一个整数N(1<=N<=1000),表示待查询的类型的数量。以下N行,每行给出一种类型。
输出格式:
每行一个整数,表示输入中类型对应的字节数。
输入样例:
6
char
long long
char
int
long
__int128
输出样例:
在这里给出相应的输出。例如:
1
8
1
4
4
16
代码示例(仅供参考):
#include#include int getByteofType(char t[15]) { //gets(char); if(strcmp(t,"char")==0) { printf("1n"); } if(strcmp(t,"int")==0) { printf("4n"); } if(strcmp(t,"long")==0) { printf("4n"); } if(strcmp(t,"long long")==0) { printf("8n"); } if(strcmp(t,"__int128")==0) { printf("16n"); } if(strcmp(t,"float")==0) { printf("4n"); } if(strcmp(t,"double")==0) { printf("8n"); } if(strcmp(t,"long double")==0) { printf("16n"); } return 0; } int main() { int n; scanf("%d",&n); char a; a=getchar(); int i; char t[15]; for(i=1;i<=n;i++) { gets(t); getByteofType(t); } return 0; }



