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;
}
相关推荐
田梓燊5 分钟前
code 560
数据结构·算法·哈希算法
笨笨饿10 分钟前
29_Z变换在工程中的实际意义
c语言·开发语言·人工智能·单片机·mcu·算法·机器人
kobesdu27 分钟前
综合强度信息的激光雷达去拖尾算法解析和源码实现
算法·机器人·ros·slam·激光雷达
艾为电子37 分钟前
【技术帖】让接口不再短命:艾为 C-Shielding™ Type-C智能水汽防护技术解析
c语言·开发语言
weixin_4130632138 分钟前
记录 MeshFlow-Online-Video-Stabilization 在线稳像
算法·meshflow·实时防抖
会编程的土豆1 小时前
【数据结构与算法】动态规划
数据结构·c++·算法·leetcode·代理模式
炘爚1 小时前
深入解析printf缓冲区与fork进程复制机制
linux·运维·算法
迈巴赫车主2 小时前
蓝桥杯19724食堂
java·数据结构·算法·职场和发展·蓝桥杯
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 78. 子集 | C++ 回溯算法题解
c++·算法·leetcode
Kethy__2 小时前
计算机中级-数据库系统工程师-数据结构-查找算法
数据结构·算法·软考·查找算法·计算机中级