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语言中,
unsigned
和void
都是保留关键字,它们有着不同的用途和特性。
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