C语言日常刷题 3

文章目录


题目

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);

2.请问下列表达式哪些会被编译器禁止【多选】( )

c 复制代码
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 = 43 C: e=&a D: f=0x321f

3.以下程序的输出结果为( )

c 复制代码
#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: * * *

4、下面代码段的输出是( )

c 复制代码
int main()
{
int a=3;
printf("%d\n",(a+=a-=a*a));
return 0;
}

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

5、下列不能实现死循环的是( )

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

6、首先输入要输入的整数个数 n ,然后输入 n 个整数。输出为 n 个整数中负数的个数,和所有正整数的平均值,结果保留一位小数。

注意: 0 即不是正整数,也不是负数,不计入计算; 本题有多组输入用例。

示例:

输入: 5

1 2 3 4 5

10

1 2 3 4 5 6 7 8 9 0

输出: 0 3.0

0 5.0

答案与解析

1

正确答案:A

参数a是指针,要接收地址,BD错误。参数b可以接收的是char*,而&c的类型是char(*)[10],C错误

2

正确答案:ABCD

如果 const 位于 * 的左侧,则 const 就是用来修饰指针所指向的变量,即指针指向为常量;c和 d不能变。

如果 const 位于 * 的右侧,则 const 就是修饰指针本身,即指针本身是常量;e和f不能变。

3

正确答案:A

全局变量i,在main()中修改为5,第一次在prt()中执行循环输出三次'*',i被修改为8,回到main()中第二次调用prt()时,i<8

为假,循环结束没输出,执行一次print("\t"),再次回到主函数后i++变为9,i<=8为假,循环结束;

4、

正确答案:D

a+=a-=aa等价于a=a+(a=a-a a),即先计算a=a-aa,所以此时a的值为3-33=-6,再计算-6+(-6)=-12赋值给a,所以a的值为-12,也就是整个表达式的值,所以应选择D

5、

正确答案:D

只有条件为真时才进行循环,非0为真,0为假;ABC中1为真,D中0为假

6、

c 复制代码
int main() 
{
    int n = 0;
    scanf("%d", &n);//整数个数
    int arr[1000];
    int i = 0;
    int count1 = 0;
    int count2 = 0;
    int j = 0;
    for (i = 0; i < n; i++)
    {
        scanf("%d", &arr[i]);//在数组中输入n个值
    }
    for (i = 0; i < n; i++)
    {
        if (arr[i] < 0)
            count1++;//负整数计数
        if (arr[i] > 0)
        {
            j += arr[i];//将所有正整数加起来
            count2++;//正整数计数
        }
    }
    float m = 0;
    if (count2 != 0)
    //正整数数目不为0
    //保证分母不为0
    {
        m = (float)j / (count2);
        //计算正整数均值
        //将j强制转换为浮点数型,这样结果才会有小数
    }
    printf("%d %0.1f", count1, m);//m打印一位小数
    return 0;
}
相关推荐
小张成长计划..9 分钟前
数据结构-栈的实现
开发语言·数据结构
go546315846544 分钟前
修改Spatial-MLLM项目,使其专注于无人机航拍视频的空间理解
人工智能·算法·机器学习·架构·音视频·无人机
油泼辣子多加1 小时前
【Torch】nn.BatchNorm1d算法详解
算法
nlog3n1 小时前
基于 govaluate 的监控系统中,如何设计灵活可扩展的自定义表达式函数体系
算法·go
IT古董1 小时前
【第三章:神经网络原理详解与Pytorch入门】01.神经网络算法理论详解与实践-(2)神经网络整体结构
pytorch·神经网络·算法
ThetaarSofVenice1 小时前
垃圾收集相关算法Test
java·jvm·算法
小陈phd2 小时前
langchain从入门到精通(二十八)——RAG优化策略(六)集成多种检索器算法实现混合检索及问题转换总结
算法
是小王同学啊~2 小时前
(LangChain)RAG系统链路向量检索器之Retrievers(五)
python·算法·langchain
小林C语言2 小时前
C语言 | 判断是否为回文数
c语言
薰衣草23332 小时前
一天两道力扣(1)
算法·leetcode·职场和发展