c语言经典测试题2

1.题1

我们来思考一下它的结果是什么?

我们来分析一下:\\是转义为字符'\',\123表示的是一个八进制,算一个字符,\t算一个字符,加上\0,应该有13个,但是strlen只计算\0前的字符个数。所以结果应该是12.我们来看看:

2.题2

大家来思考一下结果是什么呢?

我们来分析一下:前两个#define定义了两个常量,后面的#define定义了一个宏,当我们代码运行时会直接进行替换:(N+1+1)*N+1/2 这个式子运算结果为8.5,但是我们编译器会默认整型存入,我们后来使用%d打印出来,结果应该为8.我们运行看看:

3.题3

这题是一个递归,这个代码的运行结果会是多少呢?在每次的调用中我们的i的数是一直在改变的,每次的调用都会加1,最后一次调用时i=3,n=4,所以结果应该为7,这是因为static修饰局部变量使之成为全局变量,它的值只有到程序结束才会销毁,如果我们将static去掉的话,每次调用f()函数时,i都会初始为1,并不会随着调用的次数数值跟着增加。如果是这样的话结果应该为5。

我们来看一下结果:

4.题4

我们先来分析一下:我们创建了一个char类型的数组,并使用循环来将其赋值,那么arr中的数值将是:-1 -2 -3....-128 127 126 125.....0 ,有人会问为啥-128减1等于127呢?这个问题大家可以看我之前的篇章------数据在内存中的存储。那这样的话strlern的计算结果是多少呢?我们知道strlen是计算\0之前的字符的个数,其实就是在找0,我们只要计算0之前有多少个字符即可,那样的话应该就是255。

我们运行看看:

5.题5.实现代码(输入一行,每行空格分割,分别是年,月,日,输出是这一年的第几天)

cpp 复制代码
int leapyear(int year)
{
	if ((year % 400 == 0) || (year % 4 == 0 && year % 100 != 0))
	{
		return 1;
	}
	else
		return 0;
}
int getday(int year, int month, int day)
{
	int arr[] =  {  0,31,28,31,30,31,30,31,31,30,31,30,31 };  
	//               0 1  2  3  4  5  6  7  8  9  10 11 12
	int num = 0;
	int n = month;
	while (month)
	{
		num = num + arr[month--];
	}
	if (leapyear(year) == 1 && n >= 2)
	{
		num++;
	}
	num = num + day;
	return num;
}
int main()
{
	int year, month, day = 0;
	scanf("%d %d %d", &year, &month, &day);
	int ret=getday(year,month,day);
	printf("共%d天",ret);
	return 0;
}

大家可以思索一下为何要这样写,当然这只是一种方法,大家可以发挥自己的想象力试一试。

谢谢

相关推荐
踏着七彩祥云的小丑2 小时前
pytest——Mark标记
开发语言·python·pytest
Dream of maid3 小时前
Python12(网络编程)
开发语言·网络·php
W23035765733 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
.Ashy.3 小时前
2026.4.11 蓝桥杯软件类C/C++ G组山东省赛 小记
c语言·c++·蓝桥杯
Y4090013 小时前
【多线程】线程安全(1)
java·开发语言·jvm
2401_892070983 小时前
链栈(链式栈) 超详细实现(C 语言 + 逐行精讲)
c语言·数据结构·链栈
不爱吃炸鸡柳3 小时前
Python入门第一课:零基础认识Python + 环境搭建 + 基础语法精讲
开发语言·python
minji...4 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
Dxy12393102164 小时前
Python基于BERT的上下文纠错详解
开发语言·python·bert