c语言几道易错题

1、猜其打印结果

cpp 复制代码
int main()
{
	int i = 0;
	i--;

	if (i > sizeof(i))
		printf(">");
	else
		printf("<");


	return 0;
}

结果是">" ,因为sizeof操作符的结果其实是无符号型,这个时候signed要进行算术转换,变成unsigned,-1【1111111111111111111111111111111】在无符号int中对应的是极大的值,远大于1

所以结果是">"

一个表达式中既有有符号又有无符号,会将有符号转换为无符号,进行运算,就是向上转换

|-----|--------------|----------|-------------------|-------|--------|-------------|
| int | unsigned int | long int | unsigned long int | float | double | long double |
[算术转换]

--------------------------------------------------------------------------------------------------------------------------->>>

向上提升

2、求a,b,c 的值

cpp 复制代码
int main()
{
	int a, b, c;
	a = 5;
	c = ++a;
	b = ++c, c++, ++a, a++;
	b += a++ + c;

	printf("%d %d %d\n", a, b, c);

	return 0;
}

=的优先级高于 , +=的优先级比 + 低

9 23 8

3、求a的值

cpp 复制代码
int a = 1;

void test()
{
	int a = 2;
	a += 1;
}

int main()
{
	test();
	printf("%d", a);

	return 0;
}

结果是 1

在函数test中的 a 是咱们定义的局部变量,当局部变量和全局变量冲突是,在局部的时候优先局部变量,咱们已经在局部声明它是个局部变量,所以无论它在局部如何变化,都不影响全局变量a

如果我们把test()中的 int a=2中的int 去掉,答案就变成了 3,因为这个时候a没有声明是局部变量,我们在使用的时候,就认为是是全局变量的那个a

4、关于指针说法,下列哪个正确?

A、int* const p 与 int const *p 等价

B、const int *p与int *const p 等价

C、const int*p与int const *p等价

D、int *p[10] 与 int(*p)[10]等价

a、左const修饰 p ;右修饰*p,不等价

b、与上面相反

c、都是修饰*p,不能随意改变*p指向的对象 √

d、int* p[10] 与 int (*p)[10]不等价

前者定义了一个指针数组,其中包含10个指针(地址)

后者定义了一个指针p,指向了一个包含10个int型元素的数组

相关推荐
枕星而眠几秒前
Linux 线程:原理、属性、实战与面试避坑
linux·运维·c语言·面试
心中有国也有家17 分钟前
hccl 架构拆解:昇腾集合通信库到底在做什么?
人工智能·经验分享·笔记·分布式·算法·架构
小O的算法实验室1 小时前
2026年MCS,Q-learning增强MOPSO与改进DWA融合算法+复杂三维地形下特定移动机器人动态路径规划
算法
码完就睡1 小时前
C语言——动态内存
c语言·开发语言
Peter·Pan爱编程2 小时前
10. new_delete 不是 malloc_free 的包装
c++·人工智能·算法
故事和你913 小时前
洛谷-【动态规划1】动态规划的引入2
开发语言·数据结构·c++·算法·动态规划·图论
重生之我是Java开发战士3 小时前
【动态规划】背包问题:完全背包,二位费用的背包问题,似包非包
算法·动态规划
LabVIEW开发3 小时前
LabVIEW实现FDTD 电磁仿真
算法·labview·labview知识·labview功能·labview程序
Together_CZ4 小时前
DTSemNet :Vanilla Gradient Descent for Oblique Decision Trees——用于倾斜决策树的普通梯度下降
算法·决策树·机器学习·vanilla·gradient·dtsemnet·用于倾斜决策树的普通梯度
一条大祥脚4 小时前
ABC459 贪心构造|树形DP|组合数学|贪心|单调栈|势能|前缀和
算法·深度优先