C语言练习题解析:挑战与突破,开启编程新篇章!(3)

2023-09-04 19:51:36

在这里插入图片描述


🎈前言:

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

🌴选择题

  1. 已知函数的原型是: int fun(char b[10], int *a); ,设定义: char c[10];int d;正确的调用语句是( )

A: fun(c,&d);   B: fun(c,d);   C: fun(&c,&d);   D: fun(&c,d);

🔎正确答案:A
【解析】:
参数a是指针,要接收地址,所以BD错误。参数b可以接收的是char*,而&c的类型是char(*)[10],C错误

  1. 请问下列表达式哪些会被编译器禁止【多选】( )
int a = 248, b = 4;
int const* c = 21;
const int* d = &a;
int* const e = &b;
int const* const f = &a;

A: *c = 32;B: *d = 43C: e=&aD: f=0x321f

🔎正确答案:ABCD
【解析】:

  • A: *c = 32; - 这是错误的,因为 c 是一个指向常量整数的指针,意味着不能通过这个指针来修改所指向的值。编译器会禁止这个操作。
  • B: *d = 43; - 这是错误的,因为 d 是一个指向整数的指针,尽管它指向一个非常量整数 a,但是由于指针本身被声明为指向常量的,所以不能通过这个指针来修改所指向的值。编译器会禁止这个操作。
  • C: e = &a; - 这是错误的,因为 e 被声明为一个指向整数的常量指针,一旦指针被初始化,就不能再指向其他变量。编译器会禁止这个操作。
  • D: f = 0x321f; - 这是错误的,因为 f 被声明为一个指向常量整数的常量指针,一旦指针被初始化,就不能再指向其他变量。编译器会禁止这个操作。

【拓展】:

  • 如果 const 位于 * 的左侧,则 const 就是用来修饰指针所指向的变量,即指针指向为常量;即*c*d不能变。
  • 如果 const 位于 * 的右侧,则 const 就是修饰指针本身,即指针本身是常量;即ef不能变。
  1. 以下程序的输出结果为( )
#include <stdio.h>
int i;
void prt()
{
	for (i = 5; i < 8; i++)
		printf("%c", '*');
	printf("\t");
}
int main()
{
	for (i = 5; i <= 8; i++)
		prt();
	return 0;
}

A: ***   B: *** *** *** ***   C: *** ***   D: * * *

在这里插入图片描述

🔎正确答案:A
【解析】:
全局变量i,在main()中修改为5,第一次在prt()中执行循环输出三次'*'i被修改为8,回到main()中第二次调用prt()时,i<8为假,循环结束没输出,执行一次print("\t"),再次回到主函数后i++变为9i<=8为假,循环结束。

  1. 下面代码段的输出是( )
#include<stdio.h>
int main()
{
	int a = 3;
	printf("%d\n", (a += a -= a * a));
	return 0;
}

A: -6   B: 12   C: 0   D: -12

在这里插入图片描述

🔎正确答案:D
【解析】:
a+=a-=a*a等价于a=a+(a=a-a*a),即先计算a=a-a*a,所以此时a的值为3-3*3=-6,再计算-6+(-6)=-12赋值给a,所以a的值为-12,也就是整个表达式的值,所以应选择D

  1. 下列不能实现死循环的是( )

A: while(1){}   B: for(;1;){}   C: do{}while(1);   D: for(;0;){}

🔎正确答案:D
【解析】:
只有条件为真时才进行循环,ABC中1为真,D中0为假


🌴编程题

📌记负均正

【牛客网链接:HJ97 记负均正

【题目信息】:
在这里插入图片描述
【答案解析】:

  • 这道题其实通过 scanf 捕捉数据即可,统计负数个数,以及正数个数,并且在统计正数个数的过程中求取正数总和,最后计算得出平均数即可。需要注意的是所有数字中0是不统计在内的。
#include <stdio.h>
int main()
{
	int n;
	while (~scanf("%d", &n))//多组输入 (也可以写成 scanf("%d",&n)!=EOF )
	{
		int count1 = 0, count2 = 0, tmp;
		double sum = 0;
		for (int i = 0; i < n; i++) 
		{
			scanf("%d", &tmp);//对每次输入的整数进行判断
			if (tmp < 0) 
			{
				count1++; //统计负数个数
			}
			else if (tmp > 0) 
			{
				sum += tmp; //正数求和
				count2++; //统计大于0的正数个数,这样是因为题目说明0不算在内
			}
		}
		printf("%d ", count1);
        if (count2==0)//如果没有正数,则平均值为0 
        {
            printf("%.1lf\n",0.0);
        }
        else//若有正数,则平均值为所有正数的和除以正数的个数
        {
            printf("%.1lf\n",sum / count2);
        }
	} 
	return 0;
}

📌旋转数组的最小数字

【牛客网链接:JZ11 旋转数组的最小数字

【题目信息】:
在这里插入图片描述
【答案解析】:

  • 暴力破解:遍历数组找出最小值即可(时间复杂度:O(N)
//暴力破解:遍历数组找出最小值即可
int minNumberInRotateArray(int* nums, int numsLen) {
	int i = 0;
	for (i = 0; i < numsLen - 1; i++)
	{
		if (nums[i] > nums[i + 1])//只要出现降序则说明出现了最小值,比如[4,5,1,2,3] :5到1是降序,则1就是最小值;
			return nums[i + 1];
	}
	return nums[0];//如果没出现降序,说明没旋转,则第一个数就是最小值。
}
  • 更优思想:采用二分查找,这个题主要分析三种旋转情况 [1, 2, 3, 4, 5],使用中间值与右端进行比较。
    时间复杂度:O(logN)
    1. 中间大于右边 [3, 4, 5, 1, 2],这种情况下,最小数一定在右边;则left = middle + 1
    2. 中间等于右边 [1, 0, 1, 1, 1], 这个是[0, 1, 1, 1, 1] 旋转过来的,这时候需要缩小范围 right--;,注意不能是left++,因为是非降序数组,所以要缩小右边范围,把较小值向右推,符合我们的判断规则。
    3. 中间小于右边 [5, 1, 2, 3, 4], 这种情况下,最小数字则在左半边;则right = middle
//更优思想:采用二分查找
int minNumberInRotateArray(int* nums, int numsLen) {
	int left = 0;
	int right = numsLen - 1;
	while (left < right)
	{
		int mid = left + (right - left) / 2;//避免整数溢出
		if (nums[mid] > nums[right])
		{
			left = mid + 1;//最小值在[left+1,right]
		}
		else if (nums[mid] == nums[right])
		{
			right--;//缩短数组,将最小值范围右移
		}
		else
		{
			right = mid;//最小值在[left,mid]
		}
	}
	return nums[left];
}

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

在这里插入图片描述

更多推荐

ASIC-WORLD Verilog(11)过程时序控制

写在前面在自己准备写一些简单的verilog教程之前,参考了许多资料----Asic-World网站的这套verilog教程即是其一。这套教程写得极好,奈何没有中文,在下只好斗胆翻译过来(加了自己的理解)分享给大家。这是网站原文:VerilogTutorial这是系列导航:Verilog教程系列文章导航过程块和时序控制

深入浅出学Verilog--基础语法

1、简介Verilog的语法和C语言非常类似,相对来说还是非常好学的。和C语言一样,Verilog语句也是由一连串的令牌(Token)组成。1个令牌必须由1个或1个以上的字符(character)组成,令牌可以是:注释(Comment)空白符(Whitespace)运算符(Operator)数字(Number)字符串(

新手如何学习RPA,怎么学,从哪下手,学习资源哪里来?

随着人工智能技术的迅速发展,RPA(RoboticProcessAutomation)已经成为企业自动化流程的一个重要工具。越来越多的新手开始学习RPA技术,以便在职场中获得更多的竞争优势。本文将介绍新手如何学习RPA,从哪里开始学习,以及有哪些学习资源可以利用。一、了解RPA基础知识学习RPA的第一步是了解其基础知识

S7通信协议的挑高点

目录1.S7协议之布尔操作2.S7协议之PDU读取3S7协议之多组读取在电气学习的路上,西门子PLC应该是每个人的启蒙PLC,从早期的S7-300/400PLC搭建Profibus-DP网络开始接触,到后来的S7-200SmartPLC,再到现在的S7-1200/1500PLC博途软件。西门子S7协议是非常强大的一个协

面向对象的分析与设计(精品课程)第一章作业

面向对象的分析与设计(精品课程)第一章作业一.单选题(共2题,18分)二.多选题(共3题,27分)三.填空题(共5题,45分)四.简答题(共1题,10分)一.单选题(共2题,18分)(单选题)如果想对一个类的意义进行描述,那么应该采用()。A标记值B规格描述C注释D构造型(单选题)()模型的缺点是缺乏灵活性,特别是无法

Centos 7 部署SVN服务器

一、安装SVN1、安装Subversionsudoyum-yinstallsubversion2、验证是否安装成功(查看svn版本号)svnserve--version二、创建版本库1、先建立目录,目录位置可修改mkdir-p/var/svncd/var/svn2、创建版本库,添加权限svnadmincreate/va

5-3 pytorch中的损失函数

一般来说,监督学习的目标函数由损失函数和正则化项组成。(Objective=Loss+Regularization)Pytorch中的损失函数一般在训练模型时候指定。注意Pytorch中内置的损失函数的参数和tensorflow不同,是y_pred在前,y_true在后,而Tensorflow是y_true在前,y_p

如何通过AI视频智能分析,构建着装规范检测/工装穿戴检测系统?

众所周知,规范着装在很多场景中起着重要的作用。违规着装极易增加安全隐患,并且引发安全事故和质量问题,例如,在化工工厂中,倘若员工没有穿戴符合要求的特殊防护服和安全鞋,将有极大可能受到有害物质的侵害,对身体健康和生命安全带来严重的威胁。TSINGSEE青犀视频AI算法平台的着装规范检测/工装穿戴检测算法,是基于AI深度学

【启发式搜索】

运用启发式策略的两种基本情况:(1)一个问题由于存在问题陈述和数据获取的模糊性,可能会使它没有一个确定的解。(2)虽然一个问题可能有确定解,但是其状态空间特别大,搜索中生成扩展的状态数会随着搜索的深度呈指数级增长。启发式信息用来简化搜索过程有关具体问题领域的特性的信息叫做启发信息。估价函数估价函数(evaluation

Linux命令教程:使用cat命令查看和处理文件

文章目录教程:使用cat命令在Linux中查看和处理文件1.引言2.cat命令的基本概述3.查看文件内容4.创建文件5.文件重定向和管道6.格式化和编辑文件7.实际应用示例7.1使用cat命令浏览日志文件7.2利用cat命令合并多个配置文件7.3使用cat命令将文件内容发送到其他命令进行处理8.注意事项和常见问题9.结

设计模式:备忘录模式

目录组件代码示例源码中使用优缺点总结备忘录模式(MementoPattern)是一种行为型设计模式,用于在不破坏封装性的前提下,捕获和恢复对象的内部状态。备忘录模式可以将对象的状态保存到备忘录对象中,并在需要时从备忘录对象中恢复状态,实现对象状态的保存和回滚。组件在备忘录模式中,通常包含以下角色:发起人(Origina

热文推荐