当前位置: 首页 > article >正文

2019计挑赛c语言

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.kler.cn/a/397453.html

相关文章:

  • go环境搭建
  • 什么是MySQL,有什么特点
  • Nginx 上安装 SSL 证书并启用 HTTPS 访问
  • 支持向量机SVM——基于分类问题的监督学习算法
  • 北京大学c++程序设计听课笔记101
  • react 中 useEffect Hook 作用
  • python的matplotlib实现数据分析绘图
  • 算法---找出一组序列中的第k小(大)的元素
  • 每日算法一练:剑指offer——栈与队列篇(1)
  • OTX 架构开发需求分析
  • JAVA_单例模式
  • 安全生产管理的重要性:现状、痛点与改进之路
  • Android 12.0 第三方app授予DeviceOwner权限调用系统reboot,显示隐藏app,锁屏,禁用app等功能系统层部分实现
  • Java中的HTML元素设置:背景、列表与超链接
  • Docker占用空间太大磁盘空间不足清理妙招
  • 深度学习在边缘检测中的应用及代码分析
  • 保存数据到Oracle时报错ORA-17004: 列类型无效: 1111
  • 【第四期书生大模型实战营基础岛】L1G4000——LlamaIndex+InternLM RAG 实践
  • C语言模块化概述
  • LeetCode100之环形链表(141)--Java
  • HashMap源码分析上-红黑树
  • 「Mac玩转仓颉内测版7」入门篇7 - Cangjie控制结构(下)
  • [系统安全] PE文件知识在免杀中的应用
  • Spring:DI依赖注入的方式
  • Kafka 到 Kafka 数据同步
  • 牛客挑战赛77