本文主要是介绍计算机导论——数制及数据表示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
分析:负数在内存中以二进制补码形式保存,按代码运行时,
a的值满足要求,short int 包含有符号和无符号型,可以正确输出-1;
b是由unsigned int型定义的,是无符号型,所以b的值,即-1不能正确输出,结果可能时不可知的一个数
实验代码:
#include<stdio.h>
int main()
{short int a=-1;short unsigned int b=-1;printf("a=%d b=%u",a,b);return 0;
}
实验截图:
结果及分析:a=ffffffff a=37777777777 b=6.553500e+004 b=ffff
负数a和b在内存中以二进制补码形式保存,运行时,
该程序将a分别以十六进制和八进制输出,将b换成浮点型后以科学计数法形式以及直接以十六进制输出。
实验代码:
#include<stdio.h>
int main()
{short int a=-1;short unsigned int b=-1;printf("a=%x a=%o b=%e b=%x \n",a,a,(float)b,b);return 0;
}
实验截图:
猜想:输出结果应该是b=2.2345671 单精度浮点型的有效数字是7位
所以最后一位的1应该不会被保存下来
实验代码:
#include<stdio.h>
int main()
{float a=1.2345671,b;b=a+1;printf("b=%f",b);return 0;
}
实验截图:
实验分析:
char a=’x’;即将字符x保存在了字符型变量a中,再分别以字符型和x对应的ASCII码值,即120输出,字符型数据在内存中本就以ASCII码值保存在。
实验代码:
#include<stdio.h>
int main()
{char a='x';printf("a=%c,a=%d",a,a);return 0;
}
实验截图:
实验分析:
char c[50],即定义了一个长度为50的字符型数组,用来储存字符型数据,再以%s即字符串的形式输出,即原封不动输出原来定义的字符数据。
实验代码:
#include<stdio.h>
int main()
{char c[50]="这是最后一题了,贼开心!";printf("%s",c);return 0;
}
实验截图:
这篇关于计算机导论——数制及数据表示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!