【C刷题】day3
一、选择题
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
【解析】:
考点:&的使用(可以看这篇文章:一招教你scanf什么时候要加&,什么时候不用加&)
如果要传地址:
对于本身无法表示地址信息的,要加&;
本身表示的就是地址信息的,既不需要加&
c数组本来就表示地址,那么就不需要加&
d只是一个变量,但是fun的第二个参数要传地址,那就把d的地址取出来即&b
2、请问下列表达式哪些会被编译器禁止【多选】( )
nt 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 = 43 C: e=&a D: f=0x321f
【答案】:
ABCD
【解析】:
考点:指针常量和常量指针
const在*的左侧:表示指针指向的是常量,那么*c和*d不可修改
const在*的右侧:表示指针是个常量指针,那么e和f不可修改
总结来说:就是const后面跟的是啥,啥就不能直接改变
3、以下程序的输出结果为( )
#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
【解析】:
考点:for循环的逻辑+全局变量
整个代码的逻辑:
main函数中的i=5进入prt(),再次进入另一个for循环,
i=5打印一个*,i++
i=6打印一个*,i++
i=7打印一个*,i++
i=8,不满足循环条件i<8,结束循环,又回到main函数
回到main函数时i=8,此时main函数中的for循环i=5的一次循环已经结束,i++
所以i=9,那么又不满足for循环的条件,跳出循环
4、下面代码段的输出是( )
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也就得到9
那么表达式也就是a+=a-=9,也就是a=a+(a=a-9)(此时a=3)
那么a=a+(-6)(此时的a=-6),那么a=-6+(-6)=-12
5、下列不能实现死循环的是( )
A: while(1){ } B: for(;1;){ } C: do{ }while(1); D: for(;0;){ }
【答案】:
D
【解析】:
考点:C语言中0表示假,非0表示真
前三个判断条件都为1,恒为真,那么就会死循环
最后一个判断条件为0,恒为假,直接就不会进入循环
二、编程题
1.记负均正

【参考答案】:
输入n个整数时,一次输入就sum就加和
注意:被除数为0的情况要单独考虑
#include <stdio.h>
int main()
{int n = 0;int count1 = 0;int count2 = 0;int a = 0;double sum = 0;scanf("%d", &n);
//输入n个整数for (int i = 0; i < n; i++){scanf("%d", &a);//统计正数if (a > 0){sum += a;count1++;}//统计负数else if (a < 0)count2++;}//注意被除数为0的情况if (count1 != 0)printf("%d %.1lf", count2, sum / count1);elseprintf("%d 0.0", count2);return 0;
}
2.旋转数组的最小数字

【参考答案】:
本题考察:二分查找
思路:在正常的二分查找的基础上不断改进
首先通过规律发现,由于原数组是升序的,那么旋转数组的最小值左边一定是升序,右边是降序
然后就是循环的部分:
(1)当中间值大于最右边说明:mid在最小值的左边
(2)中间值小于最右边说明:mid在最小值的右边(或者就是mid)
注意1:
这里不能像正常的二分查找一样,left=mid+1;right=mid-1;(+1或者-1都可能跳过min)
那么就让left=mid;right=mid,
结果发现这样永远无法跳出循环
不断实验就让right=mid-1
注意2:
如果就像上面这样写,结果还是不正确
eg:【2,2,2,1,2】
这个情况的中间值等于最右边的值,那么就让right--(只能一个一个减,大幅度就会跳过最小值)
* @param nums int整型一维数组 * @param numsLen int nums数组长度* @return int整型*/
int minNumberInRotateArray(int* nums, int numsLen )
{int left=0;int right=numsLen-1;//找有升序有降序(最小值的左边升序,右边降序)while(left<right){int mid=(left+right)/2;if(nums[mid]>nums[right])//中间值大于最右边说明:mid在最小值的左边{left=mid+1;}else if(nums[mid]<nums[right])//中间值小于最右边说明:mid在最小值的右边(或者就是mid){right=mid;//这里不能直接像二分查找一样right=mid-1}else //这里是为了排除重复的情况,但是又不能直接right=mid,就一个一个减{right--;}}return nums[left];}
相关文章:
【C刷题】day3
一、选择题 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); 【答案…...
go 线程限制数量 --chatGPT
问:runTask(names, limit), 遍历启动以names的子名称的工作线程 name测试打印,上限数量是limit, 要求打印所有names gpt: 你可以使用 Go 协程来实现 runTask 函数,该函数会遍历启动以 names 子名称的工作线程,并在达到上限数量 …...
【Linux网络编程】日志与守护进程
日志是网络服务器程序在后台以守护进程的形式运行时,处理情况的描述被打印到了日志文件里面,方便维护人员查看。 1.前台进程与后台进程 左边会话输入命令 sleep 10000 & 代表进程后台运行,右边会话输入命令 sleep 20000可以看到命令行解…...
多输入多输出 | MATLAB实现CNN-BiGRU卷积双向门控循环单元多输入多输出
多输入多输出 | MATLAB实现CNN-BiGRU卷积双向门控循环单元多输入多输出 目录 多输入多输出 | MATLAB实现CNN-BiGRU卷积双向门控循环单元多输入多输出预测效果基本介绍程序设计往期精彩参考资料 预测效果 基本介绍 MATLAB实现CNN-BiGRU卷积双向门控循环单元多输入多输出…...
Qt: 鼠标形状设置
设置全局鼠标形状 设置完毕后,整个APP的任何窗体,包括Dialog中的鼠标形状都会被修改为设定类型,某一个控件设定的鼠标形状将被替换。一般不建议使用 QCursor cursor;//创建鼠标对象 cursor.setShape(Qt::CursorShape::ClosedHandCursor);//…...
【Oracle】Oracle系列之七--表的创建与管理
文章目录 往期回顾前言1. 表的创建2. 表的修改3. 表中数据的增删改查(1)插入数据(2)删除数据(3)更新数据 4. 表的Merge5. 表的删除6. 表的重命名7. 表的索引(1)B树索引(2…...
C/C++运算符超详细讲解(系统性学习day5)
目录 前言 一、运算符的概念与分类 二、算术运算符 三、关系运算符 四、逻辑运算符 五、赋值运算符 六、运算符的优先级 总结 前言 本篇文章是对运算符的具体讲解。 一、运算符的概念与分类 概念: 运算符就是一种告诉编译器执行特定的数学或逻辑操作的符…...
Android 遍历界面所有的View
关于作者:CSDN内容合伙人、技术专家, 从零开始做日活千万级APP。 专注于分享各领域原创系列文章 ,擅长java后端、移动开发、商业变现、人工智能等,希望大家多多支持。 目录 一、导读二、概览三、实践四、 推荐阅读 一、导读 我们…...
建筑能源管理(1)——建筑能源管理的概念
1、什么是建筑能源管理 目前,主要有三种不同的类型能源管理: (1)节约型能源管理 又称“减少能耗型”能源管理。这种管理方式着眼于能耗数量上的减少,采取限制用能的措施。例如,在非人流高峰时段停开部分电梯、在室外气温特别高时…...
SpringSecurity
明文存储密码,前加{noop}...
C++ vector模拟实现
目录 一.默认成员函数 二.扩容相关函数 三.[]重载 四.修改函数 五.迭代器 继上次写完string之后,可以写一个vector练练手以及熟悉其底层。vector是一个顺序表,相比普通数组不同点在于顺序表的数据必须是连续存放的。 一.默认成员函数 string是只存放字符…...
BUUCTF:[GYCTF2020]FlaskApp
Flask的网站,这里的功能是Base64编码解码,并输出 并且是存在SSTI的 /hint 提示PIN码 既然提示PIN,那应该是开启了Debug模式的,解密栏那里随便输入点什么报错看看,直接报错了,并且该Flask开启了Debug模式&am…...
好玩的调度技术
好玩的调度技术 文章目录 好玩的调度技术前言一、乱金柝-空间剥离二、拖拽编辑三、全端兼容 前言 最近感觉自己抑郁了,生态技术实在太庞大太复杂,所以我决定先停一段时间,在停下写生态的这两天写了几个调度的小玩意换换脑子,很有…...
Android 自定义加解密播放音视频(m3u8独立加密)
文章目录 背景加密流程音视频解密音视频播放结语 背景 当涉及App内部视频的时候,我们不希望被别人以抓包的形式来爬取我们的视频大视频文件以文件方式整个加密的话需要完全下载后才能进行解密当前m3u8格式虽然支持加密,但是ts格式的小视频可以独立播放的…...
常见的文件格式
一、C:\fakepath\新建文本文档.txt [object String] 实现方式: <input onchange"test(this.value)" type"file"></input><script>function test(e){console.log(e,Object.prototype.toString.call(e))}</script> 二、…...
浏览器输入url后回车展开过程
当你在浏览器中输入一个URL并敲下回车后,浏览器会执行一系列步骤来访问并展示网页。下面是浏览器访问网页的一般流程: DNS解析:浏览器首先会提取URL中的主机名,然后向DNS服务器发送请求,将主机名解析为对应的IP地址。这…...
Docker 容器创建命令说明
使用命令如下: docker run -itd --name=cluster -v /home/ClusterApp/cluster:/home/ClusterApp/cluster --restart=always --privileged=true -p 12000:12000 python:3.8 命令说明: docker run 创建一个容器并运行 docker run --help 可以查看所有的参数: 命令中参数说明 -…...
西瓜书读书笔记整理(六)—— 第六章 支持向量机
第六章 支持向量机 6.1 间隔与支持向量6.1.1 什么是支持向量机6.1.2 支持向量与间隔6.1.3 支持向量机的求解过程 6.2 对偶问题(dual problem)6.2.1 什么是对偶问题6.2.2 如何求解支持向量机的对偶问题 6.3 核函数(kernel function)…...
蓝桥杯每日一题2023.9.23
4961. 整数删除 - AcWing题库 题目描述 分析 注:如果要进行大量的删除操作可以使用链表 动态求最小值使用堆,每次从堆中取出最小值的下标然后在链表中删除 注意long long 代码解释: while(k --){auto t q.top();q.pop();res t.first;i…...
C语言数组和指针笔试题(三)(一定要看)
目录 字符数组四例题1例题2例题3例题4例题5例题6例题7 结果字符数组五例题1例题2例题3例题4例题5例题6例题7结果字符数组六例题1例题2例题3例题4例题5例题6例题7 结果 感谢各位大佬对我的支持,如果我的文章对你有用,欢迎点击以下链接 🐒🐒🐒个…...
从任务编排到自动化工作流:OpenClaw与Apache Airflow实战解析
1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的项目,叫Charpup/openclaw-task-workflow。光看名字,你可能会有点摸不着头脑——“Charpup”是什么?“OpenClaw”又是什么?这其实是一个典型的、由开发者社区驱动的自动化任…...
Vibe Coding:打造沉浸式编程学习环境,从环境到心流的高效开发实践
1. 项目概述:从“Vibe Coding”到沉浸式编程学习 最近在开发者社区里,一个名为“VibecodingCurriculum”的项目引起了我的注意。这个由 hashed 团队在 vibedojo 下维护的仓库,名字本身就很有意思——“Vibe Coding”,直译过来是“…...
内存数据库eXtremeDB核心技术解析与实践指南
1. 内存数据库技术概述在传统数据库系统中,磁盘I/O往往是性能瓶颈所在。每次数据查询都需要从磁盘读取数据到内存缓冲区,这个过程中涉及机械寻道、旋转延迟等物理限制。而内存数据库(IMDS)通过直接在内存中存储和处理数据,彻底绕过了这个瓶颈…...
分布式缓存策略:提升应用性能和可扩展性
分布式缓存策略:提升应用性能和可扩展性 一、分布式缓存概述 1.1 分布式缓存的定义 分布式缓存是一种将数据存储在多个节点上的缓存系统,它通过在内存中存储常用数据,减少对后端数据库的访问,从而提高应用性能和可扩展性。 1.…...
Arm CoreSight TPIU-M调试架构与寄存器配置详解
1. Arm CoreSight TPIU-M架构概述 在嵌入式系统调试领域,Arm CoreSight架构提供了一套完整的调试与跟踪解决方案。作为该架构中的关键组件,Trace Port Interface Unit-Modified(TPIU-M)承担着将处理器内部跟踪数据输出到外部调试工…...
reverse-geocoder未来展望:AI增强地理编码与智能位置预测
reverse-geocoder未来展望:AI增强地理编码与智能位置预测 【免费下载链接】reverse-geocoder A fast, offline reverse geocoder in Python 项目地址: https://gitcode.com/gh_mirrors/re/reverse-geocoder 在当今数据驱动的世界中,地理编码技术已…...
从阿里天池金融风控赛看实战:用XGBoost搞定贷款违约预测的完整流程与避坑指南
金融风控实战:XGBoost在贷款违约预测中的全流程解析 金融风控领域的机器学习应用正变得越来越普及,尤其是在贷款违约预测这一核心场景中。天池等数据竞赛平台为从业者提供了宝贵的实战演练机会,但如何将比赛经验转化为真实业务能力࿰…...
解决Modelsim SE 10.6c仿真Vivado 2019乘法器IP核的“.vhd only”难题(附完整脚本)
解决Modelsim SE 10.6c仿真Vivado 2019乘法器IP核的“.vhd only”难题(附完整脚本) 在FPGA设计流程中,Xilinx Vivado与Mentor Modelsim的组合是许多工程师的首选工具链。但当Vivado 2019生成的乘法器IP核仅提供VHDL接口文件(.vhd)时ÿ…...
sdd-riper:专业磁盘镜像工具在数据恢复中的原理与实践
1. 项目概述与核心价值最近在整理一些老旧存储设备时,遇到了一个挺典型的问题:手头有几块年代久远的硬盘,里面可能还存着一些早年间的照片、文档,但硬盘本身已经不太稳定,系统里能识别,但拷贝文件时动不动就…...
Polkadot 正在补完 L1 里没人做过的“垂直 RISC-V 集成“
作者: PaperMoon团队 位 Parity 工程师周末买了一块 RISC-V 板子,把节点跑起来看看会断在哪里。配图是一张工程师的桌子,板子、线、调试器、电源。 很多人会觉得这就是一个 maker culture 风格的小实验。但如果你把过去三年 Polkadot 在 IS…...
