2019计挑赛c语言

server/2024/11/17 18:17:53/

1.下列选项中,说法正确的是(D)。

a.函数的形参可以是常量、变量或表达式

实参可以是任何类型(可以是常量,变量或表达式),但是形参却不能是表达式

形参不能是表达式

b.函数返回值的类型是由return语句中表达式类型决定

函数返回值的类型是由函数定义时指定的类型决定的,而不是由return语句中表达式的类型决定的

c.C程序中若未给变量赋初值,则变量的初值自动为0

可能乱码为随机数,因为未给变量赋值,这个变量的初始值就是未定义的,这意味着这个变量的内容是不确定的,它可能是任何值。

d.调用函数时,如果实参是简单变量,则它与对应形参之间的数据传递是单向值传递

形参和实参的区别
1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。 

2.实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。  

3.函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。

4.当形参和实参不是指针类型时,在该函数运行时,形参和实参是不同的变量,他们在内存中位于不同的位置,形参将实参的内容复制一份,在该函数运行结束的时候形参被释放,而实参内容不会改变。

而如果函数的参数是指针类型变量,在调用该函数的过程中,传给函数的是实参的地址,在函数体内部使用的也是实参的地址,即使用的就是实参本身。所以在函数体内部可以改变实参的值。

2.下列选项正确的是(D)。

a.C语言编译时不检查语法(x,语法错误就无法编译成功)

b.结构体类型的变量,不能在声明结构体类型组成时一起定义(可以)

c.构成C语言程序的基本单位是函数,所有函数名都可以由用户命名

函数的命名规则遵循C语言的标识符命名规则,即只能包含字母、数字和下划线,并且必须以字母或下划线开头,有些函数,比如主函数main就不能由用户来命名;库函数的函数名由系统定义

d.C语言在定义函数时省略extern,则默认是外部函数

在C语言中,extern关键字通常用于在头文件中声明全局变量或函数,然后在源文件中进行定义。这样可以将变量或函数的声明和定义分离,使代码更加模块化和可扩展。

    1. 函数和变量的声明不会分配内存, 但是定义会分配相应的内存空间

    2. 函数和变量的声明可以有很多次, 但是定义最多只能有一次

    3. 函数的声明和定义方式默认都是 extern 的, 即函数默认是全局的

    4. 变量的声明和定义方式默认都是局部的, 在当前编译单元或者文件内可用

3.下列选项正确的是(A)。

a.C语言程序中注释部分可以出现在程序中任意合适的地方

b.结构体类型中的各个成分均不能是数组或指针(x)

结构体是一种自定义数据类型,它允许其成员包含数组和指针。结构体中的成员可以是基本数据类型、数组类型、指针类型、指针数组、数组指针、函数指针等

c.C语言的函数可以嵌套定义

在C语言中,函数不能嵌套定义,但可以嵌套调用‌ 函数的定义都是相互平行、相互独立的,这意味着在函数定义时,函数体内不能包含另一个函数的定义。‌1

嵌套调用是指在一个函数内部调用另一个函数。虽然C语言不允许在函数内部定义另一个函数,但它允许在函数内部调用另一个已经定义的函数。

d.元素为结构体类型的数组,只能在声明过结构体类型之后,单独进行定义(x)

4.下列选项正确的是(A)。

a.使用typedef定义新类型名后,新类型名与原类型名实际上是等价的

b.花括号“{“和”}”只能作为函数体的定界符

花括号“{”和“}”不仅可以用作函数体的定界符,还可以用于定义代码块、结构体、数组的初始化以及控制语句的复合

c.C语言的子程序有过程和函数两种

C语言中没有过程的概念,只有函数。 

d.分号是C语句之间的分隔符,不是语句的一部分(X,分号是语句的一部分)

5.下列选项中错误的是(D)。

a.unsigned 和 void 在 C 中都是保留字

在C语言中,unsignedvoid都是保留关键字,它们有着不同的用途和特性。

b.树形结构中元素之间存在一对多的关系(对)

c.C语言程序的基本组成单位是函数(对)

d.在C语言程序中,注释说明只能位于一条语句的后面(错,注释哪里都可以)

6.下列四种排序方法中,适合处理大量数据的是(D)。

a冒泡排序

b.直接插入排序

c.快速排序

d.堆排序

7.对序列[8 6 7 5 4]进行递减冒泡排序,则第三趟排序后的序列为(D)。

d.8 7 6 5 4

void solve()
{cin>>n;for(int i=0;i<n;i++){cin>>a[i];}for(int i=0;i<3;i++){for(int j=0;j<n-i-1;j++){if(a[j]<a[j+1

http://www.ppmy.cn/server/142706.html

相关文章

工业相机选取

1.相机分类&#xff1a; 1.1 在相机曝光方式中&#xff0c;全局曝光和卷帘曝光是两种主流技术。CCD相机通常采用全局曝光方式&#xff0c;而CMOS相机则可能采用卷帘曝光。 面阵相机与全局曝光关联与区别 关联&#xff1a;面阵相机可以使用全局曝光作为曝光方式&#xff0c;但…

github 以及 huggingface下载模型和数据

runningcheese/MirrorSite: 镜像网站合集 (github.com) huggingface 下载模型和数据使用snapshot_download的方法 不会修改HuggingFace模型下载默认缓存路径&#xff1f;一篇教会你!_huggingface默认下载路径-CSDN博客 下载模型 使用snapshot_download 使用snapshot_down…

当kafka消费的数据滞后1000条时,打印告警信息

要在 Kafka 消费者中实现当数据滞后1000条时打印告警信息&#xff0c;你需要在消费循环中添加逻辑来检查当前消费者的偏移量与主题中的最新偏移量之间的差异。如果这个差异大于1000&#xff0c;就打印告警信息。以下是修改后的代码示例&#xff1a; package com.mita.web.core.…

第二十一周机器学习笔记:动手深度学习之——数据操作、数据预处理

第二十周周报 摘要Abstract一、动手深度学习1. 数据操作1.1 数据基本操作1.2 数据运算1.2.1 广播机制 1.3 索引和切片 2. 数据预处理 二、复习RNN与LSTM1. Recurrent Neural Network&#xff08;RNN&#xff0c;循环神经网络&#xff09;1.1 词汇vector的编码方式1.2 RNN的变形…

常见git命令记录

记录一些常见的git操作 下载代码 下载 git clone [代码连接] 切分支 git branch -b [分支名] 提交代码 添加 git add [需要提交的代码路径] 提交 git commit -m "一些骚话" push git push origin HEAD:refs/for/[仓名称] 通过diff文件&#xff0c;同步修…

PCL 点云拟合 最小二乘法拟合平面

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.1.1计算点云质心 2.1.2最小二乘法拟合平面 2.1.3可视化函数 2.2完整代码 三、实现效果 PCL点云算法汇总及实战案例汇总的目录地址链接: PCL点云算法与项目实战案例汇总(长期更新) 一…

Dubbo 使用轻量的 Java SDK 开发 RPC Server 和 Client

本示例演示如何使用轻量 Dubbo SDK 开发 RPC Server 与 Client&#xff0c;示例使用 Java Interface 方式定义、发布和访问 RPC 服务&#xff0c;底层使用 Triple 协议通信。本示例完整代码请参见 dubbo-samples。 基于 Dubbo 定义的 Triple 协议&#xff0c;你可以轻松编写浏…

mindtorch study

安装 pip install mindtorch mindtorch 用于帮助迁移torch模型到mindspore 大部分都可以直接把mindtorch的torch搞成torch&#xff0c;就和以前的代码一致&#xff0c;注意下面 只有静态图有点点差异 step也有差异 自定义优化器就麻烦了。 pyttorch还是牛啊 并行计算还是用的…