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;
}
相关推荐
keep intensify11 小时前
最小覆盖子串
算法
仟濹11 小时前
【算法打卡day35(2026-03-31 周二)】DFS专项训练2(今日算法:DFS & 记忆化搜索 & 回溯)
c++·算法·蓝桥杯·深度优先
炽烈小老头11 小时前
【每天学习一点算法 2026/04/02】最长递增子序列
学习·算法
IronMurphy11 小时前
【算法三十五】22. 括号生成
算法
liuyao_xianhui11 小时前
优选算法_岛屿的最大面积_floodfill算法_C++
java·开发语言·数据结构·c++·算法·leetcode·链表
赵域Phoenix11 小时前
Origin导入xlsx数据解锁编辑
算法
寻寻觅觅☆11 小时前
东华OJ-基础题-33-数字之和(C++)
数据结构·c++·算法
co_wait12 小时前
【C语言】字符串处理函数
c语言·开发语言
激昂网络12 小时前
用CT001解读Type-C线材设计:为什么只有一个CC灯亮?
c语言·开发语言·嵌入式硬件
算AI12 小时前
重绘多孔世界的蓝图:GAN助力多孔材料的数字重构
人工智能·深度学习·算法·机器学习·生成对抗网络·ai