C语言好题解析(一)

目录

选择题1

执行下面程序,正确的输出是( )
c 复制代码
int x = 5, y = 7;
void swap()
{
	int z;
	z = x;
	x = y;
	y = z;
} int main()
{
	int x = 3, y = 8;
	swap();
	printf("%d,%d\n",x, y);
	return 0;
}
A: 5,7    B: 7,5    C: 3,8    D: 8,3

【答案】 C

【分析】 首先我们可以看到x和y有两个不同的值,为x=5和3,y=7和8,其中x=5和y=7的范围比x=3和y=8的范围更大(即作用域更大),而printf函数有一个就近原则 ,即输出与它最近的x和y,swap函数则是将x=5和y=7进行交换(因为swap函数没有就近原则,而x=5和y=7作用域更大

选择题2

以下不正确的定义语句是( )
A double x[5] = {2.0, 4.0, 6.0, 8.0, 10.0};
B char c2[] = {'\x10', '\xa', '\8'};
C char c1[] = {'1','2','3','4','5'};
D int y[5+3]={0, 1, 3, 5, 7, 9};

【答案】 B

【分析】\8表示8进制的8,而8进制的数字表示为0~7,因此\8表示错误

选择题3

若给定条件表达式 (M)?(a++):(a--) ,则其中表达式 M ()
A: 和(M==0)等价 B: 和(M==1)等价 C: 和(M!=0)等价 D: 和(M!=1)等价

【答案】 C

【分析】(M)?(a++):(a--)的含义为判断表达式M是否为真(M!=0)(因为为表达式,所以只要非0就为真),如果为真就a++,反之则a--

选择题4

有如下定义语句,则正确的输入语句是【多选】( )
int b;
char c[10];
A: scanf("%d%s",&b,&c); B: scanf("%d%s",&b,c);
C: scanf("%d%s",b,c); D: scanf("%d%s",b,&c);

【答案】 AB

【分析】这里可能会有人认为scanf后面都应该要有&,其实&只是为了储存数据地址,而数组可以省略&。

我们举一个例子

c 复制代码
#include<stdio.h>
void jack( int *arr)
{
	for (int i = 0; i <= 5; i++)
	{
		arr[i] = i;
	}
}
int main()
{
	int arr[6] = { 0 };
	jack(arr);
	for (int i = 0; i <= 5; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

这个代码运行结果如图

而加上&后

c 复制代码
#include<stdio.h>
void jack( int *arr)
{
	for (int i = 0; i <= 5; i++)
	{
		arr[i] = i;
	}
}
int main()
{
	int arr[6] = { 0 };
	jack(&arr);
	for (int i = 0; i <= 5; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

我们可以看出结果并没有变,所以&可加可不加。

编程题一

根据输入的日期,计算是这一年的第几天。输入保证年份为4位数且日期合法。
输入描述:输入一行,每行空格分割,分别是年,月,日。
输出描述:输出是这一年的第几天
示例:
输入:2012 12 31 输入:1982 3 4
输出:366 输出:63

牛客网题目链接

【题目分析】

1:由于每个月的天数都不一定相同,如果我们不用数组的话是非常难搞定这问题的(我去试了),因此我们需要定义一个数组,以每个月的天数为元素,按顺序输入进数组,又因为闰年的二月和非闰年的二月天数不同,因此我们要定义两个数组分别代表闰年和非闰年。

2:因为我们最后输入的日不一定是这个月的最后一天,因此我们需要少计算一个月,然后将前面月的天数相加,再加上输入的天数,即可得到最终结果

【代码】

c 复制代码
#include <stdio.h>
int main()
{
	int year, month, day,sum=0;
	scanf("%d %d %d", &year, &month, &day);
	int run[12] = { 31,29,31,30,31,30,31,31,30,31,30,31 };
	int notrun[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
	if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
	{
		for (int i = 0; i <= month - 2; i++)
		{
			sum = sum+run[i];
		}
		sum += day;
	}
	else
	{
		for (int i = 0; i <= month - 2; i++)
		{
			sum =sum+ notrun[i];
		}
		sum += day;
	}
	printf("%d", sum);
	return 0;
}
相关推荐
Kenneth風车1 分钟前
【机器学习(五)】分类和回归任务-AdaBoost算法-Sentosa_DSML社区版
人工智能·算法·低代码·机器学习·数据分析
C7211BA19 分钟前
使用knn算法对iris数据集进行分类
算法·分类·数据挖掘
Tisfy21 分钟前
LeetCode 2398.预算内的最多机器人数目:滑动窗口+单调队列——思路清晰的一篇题解
算法·leetcode·机器人·题解·滑动窗口
.普通人23 分钟前
c语言--力扣简单题目(回文链表)讲解
c语言·leetcode·链表
星迹日24 分钟前
C语言:联合和枚举
c语言·开发语言·经验分享·笔记
程序猿练习生25 分钟前
C++速通LeetCode简单第18题-杨辉三角(全网唯一递归法)
c++·算法·leetcode
Huazzi.28 分钟前
算法题解:斐波那契数列(C语言)
c语言·开发语言·算法
汉字萌萌哒29 分钟前
【2022 CCF 非专业级别软件能力认证第一轮(CSP-J1)入门级 C++语言试题及解析】
数据结构·c++·算法
2301_8071805430 分钟前
icpc江西:L. campus(dij最短路)
算法
th新港31 分钟前
CCF201909_1
数据结构·c++·算法·ccf