C语言练习题解析(1)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: C语言练习题解析(1)

🎈前言:

  • 本专栏每篇练习将包括 5个选择题 + 2个编程题,将涵盖C语言的不同方面,包括基础语法、数据类型、控制结构、数组、指针和函数等。通过练习,你将逐步掌握C语言的基础知识和常见问题,提高你的编程技巧和解决问题的能力。
  • 我希望这个博客能够为你提供有价值的练习资源,让你在实践中不断进步。同时,我们也鼓励你在练习过程中进行思考和创新,尝试使用不同的编程方法和技巧。
  • 让我们一起挑战C语言练习题,攻克每一个难点,不断提升自己的编程技能!在评论区分享你的练习心得和问题,与我们一起交流和成长。

🌴选择题

  1. 执行下面程序,正确的输出是( )
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

【解析】:

swap函数调用时用的是全局变量,主函数中定义的变量只在主函数中有效,因为主函数也是一个函数,它与其他函数是平行关系;输出语句这里,考虑局部优先的原则,故打印的x值为3y的值为8

  1. 以下不正确的定义语句是( )

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

【解析】:

本题B选项考查转义字符,有如下格式,但八进制数字是0-7,没有8,故B选项中’\8’是错误的

\ddd ddd表示1到3个八进制数 如:\130 转义为 字符X

\xhh hh表示1到2位十六进制数 如:\x30 转义为 字符0

  1. test.c 文件中包括如下语句,文件中定义的四个变量中,是指针类型的变量为【多选】( )
#define INT_PTR int*
typedef int* int_ptr;
INT_PTR a, b;
int_ptr c, d;

A: a   B: b   C: cD: d

🔎正确答案:ACD

【解析】:易错题

因为#define是宏定义,仅仅是直接替换; INT_PTR a, b, 进行宏替换后代码是这样的:int *a, b;这里的int *a的类型,b的类型是int,故此次b只是int类型。而typedef是把该类型定义一个别名,别名是一个独立的类型了,使用这个类型创建的变量都是这个类型的。所以 a,c,d才是指针类型。

  1. 若给定条件表达式 (M)?(a++):(a--) ,则其中表达式 M ( )

A: 和 (M ==0) 等价   B: 和 (M ==1) 等价   C: 和(M !=0 )等价   D: 和(M != 1)等价

🔎正确答案:C

【解析】:易错题

给定条件表达式(M)?(a++):(a--)。 (表达式1)? (表达式2): (表达式3)为三目运算符

  • 三目运算符计算规则为:先判断表达式1是否为真,若为真,则计算表达式2,并将表达式2的结果作为整个表达式最终的结果,表达式3不计算;否则,表达式3的结果为最终结果,表达式2不计算。
  • 在此表达式中,若M=0,为假,计算a--; 若M≠0,为真,计算a++; 若要求与M等价,则要满足M0时为假,取非0数值时为真。
    C选项中:假定M0,则M表示假,当M0时,表达式M!=0不成立,为假,计算a--;当M取非0数值时,M为真,表达式M!=0成立,为真,计算a++; 符合题意,选C
  1. 有如下定义语句,则正确的输入语句是【多选】( )
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

【解析】:

根据C语言中的scanf函数,正确的输入语句应该将变量的地址作为参数传递给scanf函数。

选项A和B是正确的输入语句。在选项A中,虽然在第二个参数中使用"&c" 与一般情况下使用数组名" c " (即选项B) 稍有不同,但两者地址值是一样的,程序的效果相同,因为它表示数组首元素的地址。而选项C和D均不正确,因为在读取整数时需要使用"&b"来获取变量b的地址。


🌴编程题

📌打印从1到最大的n位数

【牛客网链接:JZ17 打印从1到最大的n位数

【题目信息】:

【答案解析】:

这里首先要清楚n位数中最大的数字,实际上就是 10^n - 1 。 比如:

1位数: 10^1 - 1
2位数: 10^2 - 1
3位数: 10^3 - 1
...

这个清楚后动态申请空间,将数值填入就可以了,需要注意的是数组下标从0开始,而数值从1开始

int* printNumbers(int n, int* returnSize) 
{
  *returnSize = pow(10, n) - 1; //确定最大的数字
  int* arr = (int*)malloc(sizeof(int) * (*returnSize));//申请足够大小的空间
  for (int i = 0; i < *returnSize; i++) 
  {
    arr[i] = i + 1;//下标从0开始,而数值从1开始
  } 
  return arr;
}

【知识拓展】:

(1)pow函数

(2)malloc函数

这里只是简单的介绍了malloc函数的原型,具体如何使用还是需要大家多多探索,毕竟熟能生巧,大家只有多多练习才能提升自己的代码水平。


📌计算日期到天数转换

【牛客网链接:HJ73 计算日期到天数转换

【题目信息】:

【答案解析】:

  • 这道题简单解法其实将每个月的天数枚举出来,然后根据当前月份向前累加满月的天数,然后再加上当前月所在的
    天数。最终考虑平闰年的 2 月份区别是否增加一天。
  • 其中需要注意的是平年和闰年的判断,而且是闰年的月份大于 2 的时候,也就是 2 月走完,总天数才能加 1 (比
    如 2000年2月18日 ,虽然是闰年,但是 2月 都没走完那是不能加上闰年多出的一天的).
#include <stdio.h>
int is_leap_year(int year) //判断是否为闰年的函数
{
  if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) {
    return 1;
  } 
  return 0;
} 
int main()
{
  int month_day[] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };//下标对应月份
  int year, month, day;
  while (~scanf("%d %d %d", &year, &month, &day))//多组输入
  {
    int total_day = day;//先把当前月份天数加上
    if (is_leap_year(year) && month > 2)
    {
      total_day += 1;//若闰年,且月份大于2月,则在平年基础上+1
    }
      for (int i = month - 1; i > 0; i--) 
      {
        total_day += month_day[i];//向前累加每月的天数即可
      }
    printf("%d\n", total_day);
  }
  return 0;
}

【拓展】:注意上述代码中的 while (~scanf(“%d %d %d”, &year, &month, &day)),这条语句也可以写成 while (scanf(“%d %d %d”, &year, &month, &day)!=EOF)。

scanf是一个函数,用于从标准输入(通常是键盘)读取数据并将其存储到变量中。它的基本语法是:

scanf("%format", &variable1, variable2, ...)

其中"%format"是用于指定输入数据的格式,如整数(%d),浮点数(%f),字符(%c)等。"&variable1, variable2, …"是要存储输入的变量的地址。

然后,~是一个位运算符,表示按位取反。它对操作数的每一位进行取反,即把0变为1,把1变为0。在计算机中,数的存储是以二进制的形式进行的,所以按位取反操作可以实现对一个数的所有二进制位取反。scanf返回值是成功读取数据的个数,如果scanf遇到问题(如用户输入的不是数字,或者已经到达了文件尾),那么scanf会返回-1,-1在内存中存储的是补码,其补码是全1,所以~scanf取反后就变为全0,就会返回0,循环就会停止。


🔥今天的内容就到这里了,有什么问题的话欢迎大家在评论区讨论,也可以私信博主为你解答,如果觉得博主的文章还不错的话, 请👍三连支持一下博主哦🤞

目录
相关文章
|
17天前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
87 14
|
21天前
|
存储 算法 C语言
【C语言】深入浅出:C语言链表的全面解析
链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。通过本篇详细讲解了单链表、双向链表和循环链表的概念和实现,以及各类常用操作的示例代码。掌握链表的使用对于理解更复杂的数据结构和算法具有重要意义。
170 6
|
21天前
|
存储 网络协议 算法
【C语言】进制转换无难事:二进制、十进制、八进制与十六进制的全解析与实例
进制转换是计算机编程中常见的操作。在C语言中,了解如何在不同进制之间转换数据对于处理和显示数据非常重要。本文将详细介绍如何在二进制、十进制、八进制和十六进制之间进行转换。
29 5
|
21天前
|
C语言 开发者
【C语言】断言函数 -《深入解析C语言调试利器 !》
断言(assert)是一种调试工具,用于在程序运行时检查某些条件是否成立。如果条件不成立,断言会触发错误,并通常会终止程序的执行。断言有助于在开发和测试阶段捕捉逻辑错误。
29 5
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
73 2
|
2月前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
77 0
|
2月前
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
62 0
|
2月前
|
存储 Java C++
Collection-PriorityQueue源码解析
Collection-PriorityQueue源码解析
66 0
|
2月前
|
安全 Java 程序员
Collection-Stack&Queue源码解析
Collection-Stack&Queue源码解析
86 0
|
18天前
|
PyTorch Shell API
Ascend Extension for PyTorch的源码解析
本文介绍了Ascend对PyTorch代码的适配过程,包括源码下载、编译步骤及常见问题,详细解析了torch-npu编译后的文件结构和三种实现昇腾NPU算子调用的方式:通过torch的register方式、定义算子方式和API重定向映射方式。这对于开发者理解和使用Ascend平台上的PyTorch具有重要指导意义。

推荐镜像

更多