C语言这些题你真的会吗

第一题

1.
//输出什么?
#include <stdio.h>
int main()
{
char a= -1;
signed char b=-1;
unsigned char c=-1;
printf("a=%d,b=%d,c=%d",a,b,c);
return 0;
}

输出结果为a=-1,b=-1,c=255

题解

内存中存储的是补码,正数原码 反码 补码 相等。

#include <stdio.h>
int main()
{
	char a = -1;
	//10000000000000000000000010000001---  -1的二进制
	//10000000000000000000000011111110----- 反码
	//10000000000000000000000011111111----- 补码
	//11111111-- a中存储的发生截断

	//11111111111111111111111111111111---整形提升,char一般默认是有符号的
	//以%d形式打印,符号位为1认为是个负数
	//11111111111111111111111111111110----反码
	//10000000000000000000000000000001-----原码---打印出-1

	signed char b = -1;//b和a同理
	unsigned char c = -1;
	//10000000000000000000000010000001 --- -1的原码
	//10000000000000000000000011111110 ---- 反码
	//10000000000000000000000011111111 ------补码
	//11111111--c中存储的发生截断

	//00000000000000000000000011111111---因为b为无符号的整形提升补0
	//以%d形式打印,符号位为0认为是个正数
	//正数原反补相等
	//00000000000000000000000011111111----255
	printf("a=%d,b=%d,c=%d", a, b, c);
	return 0;
}

第二题


#include <stdio.h>
int main()
{
	char a = -128;
	printf("%u\n",a);
	return 0;
}

打印的结果为:4294967168

分析如下

#include <stdio.h>
int main()
{
	char a = -128;
	//10000000000000000000000010000000  -128原码
	//11111111111111111111111101111111 ----反码
	//11111111111111111111111110000000 ----补码

	//截断放到a中
	//10000000
	//整形提升,因为a的类型是char,char是有符号的补符号位
	//11111111111111111111111110000000
	//以%u形式打印,%u是无符号的,它认为内存中存储的也是一个无符号的数
	//11111111111111111111111110000000-----转化为10进制为‭4294967168‬
	printf("%u\n", a);
	return 0;
}

第三题

#include <stdio.h>
int main()
{
	char a = 128;
	printf("%u\n",a);
	return 0;
}

输出结果为 4294967168‬

分析如下

#include <stdio.h>
int main()
{
	char a = 128;
	//00000000000000000000000010000000   128原码(正数原反补相等)
	//char 类型占1个字节8个比特位,会发生截断
	//10000000----a中存放的

	//以%u打印需要进行整形提升,a的类型为char有符号数 符号位为1,整形提升补1
	//11111111111111111111111110000000  --整形提升
	//11111111111111111111111110000000  --十进制为 ‭4294967168‬
	printf("%u\n", a);
	return 0;
}

第四题

#include<stdio.h>
int main()
{
	char a[1000];
	int i;
	for (i = 0; i < 1000; i++)
	{
		a[i] = -1 - i;
	}
	printf("%d", strlen(a));
	return 0;
}

输出结果:255

在这里插入图片描述

题目其实是在找什么时候出现0,当i等于0是a[i]=-1,,因为数组的类型为char类型,只能存放8bit位,随着i的不断增大,a[i]中的值也会随着不断变化,在图中可以看到0出现的位置为正好走一圈,char的表示范围是-128~127,所以求得的字符串长度为128+127。

怎么样,做对了几道呢

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值