C语言好题解析(四)

目录

选择题一

复制代码
已知函数的原型是: 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);

【答案】A

【分析】
数组 :在传参时我们需要注意参数类型,对于数组而言,传参时我们可以直接省略[]和里面的数字
指针:当传参时为指针时,我们就需要注意了,指针int*a表示传入参数为整形类型的指针地址,因此表示整形地址则需&和整形类型的元素d

选择题二

复制代码
请问下列表达式哪些会被编译器禁止【多选】( )
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

【答案】ABCD

【分析】这道题注意是考察const的理解
int const c = 21因为const在 c的左边,因此为常量指针,即c是不能改变的,所以c=32错误,但是只是*c不能改变,c是可以改变的,比如c=&a ...

const int d = &a因为const在 d的左边,因此d不能改变,这个和上边的错误一样
int const e = &b const只在e的左边,因此只有e不能被改变,而e是可以改变的,因此e=&a错误,但是e=248是正确的

int const * const f = &a,我们可以看到有两个const,一个在f左边,另一个在f左边,因此不管是f还是f都是不能被改变的,f=0x321f是16进制,表示的是地址,反正不管是f还是*f改变都是错的

选择题三

复制代码
以下程序的输出结果为( )
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: * * *

【答案】A

【分析】注意int i是全局变量,因此生命周期和主函数一样,只有当程序销毁了才会消失

在prt循环后i=8,跳出prt后,主函数循环中i=8是满足i<=8,然后i++使i=9,由于i=9在prt中不满足循环条件i<8直接跳出循环,最终值输出了***

注意不是prt循环三次跳出后在主函数中再循环,然后又进prt中循环,这样的结果是B,是因为没有理解到全局变量的含义。

\t的含义约等于TAB键,可以理解为按了几次空格键

下面是我用调试对关键过程的截图

选择题四

复制代码
下面代码段的输出是( )
c 复制代码
int main()
{
int a=3;
printf("%d\n",(a+=a-=a*a));
return 0;
}
复制代码
A: -6 B: 12 C: 0 D: -12

【答案】D

【分析】这种题我觉得就和我之前写的一篇博客讲的一样操作符详解下(非常详细)有点花里胡哨,根本没必要这样来写,如果分步骤来写的话清晰明了

下面是对这道题的分析

这种算法是从右向左进行的,因此先看a-=a*a,这样算出的结果a=-6,再看a+=a,这样算出结果是-12。

选择题五

复制代码
下列不能实现死循环的是( )
A: while(1){} B: for(;1;){} C: do{}while(1); D: for(;0;){}

【答案】 D

【分析】对于while来说要想实现死循环,只需让while()里面的内容为真,并且while里面的语句没有break就可以实现死循环

而for中(;x;)x为1则为真死循环,为0则为假,不循环。

编程题一

题目链接

复制代码
首先输入要输入的整数个数 n ,然后输入 n 个整数。
输出为 n 个整数中负数的个数,和所有正整数的平均值
结果保留一位小数。
注意: 0 即不是正整数,也不是负数,不计入计算 
本题有多组输入用例。
输入描述:首先输入一个正整数 n ,然后输入 n 个整数
输出描述:输出负数的个数,和所有正整数的平均值

【题目分析】题目要求输出负数的个数和正整数的平均值,并且要排除输入0的情况,因此需要用到if语句将这几种情况分开

我们假设sum=0为统计输入负数的个数,average=0为正整数的平均值,x为输入的数字,当输入负数是sum++,而输入正整数时average+x

0这种情况就有点麻烦,我们还需要设一个y=0,当输入0时y--,并且将x赋值为1,这样x有0变到1,y由0变到-1,这样输入0是x+y就可以抵消,并且y也就统计出了输入0的个数,之后我们就可以在计算平均值时加上y,就相当于减去输入0的个数,值得注意的是负数的个数也需要减去 (我因为没有减所以一直没做出来)

【代码】

c 复制代码
#include<stdio.h>
int main()
{
	int n, sum = 0, x, y = 0;
	double average = 0;
	scanf("%d", &n);
	for (int i = 1; i <= n; i++)
	{
		scanf("%d", &x);
		if (x == 0)
		{
			x = 1;
			average += x;/*因为这样做x+y=0,
			              这样就可以抵消,
			      并且n最后也可以减掉x=0的个数*/
			y--;
		}
		else if (x > 0)
		{
			average += x;//x为正数
		}
		else
		{
			sum++;//x为负数
		}
	}
	if (n + y == 0)
		average = 0.0;//全部为0的情况
	else
	{
		average = average + y;/*不全部为0的情况
		           +y后就把x=0变成x=1的都减掉*/
		n = n + y-sum;//减去x=0的个数
		average = average / n;//算平均值
	}
	printf("%d %.1f", sum, average);
	return 0;
}
相关推荐
Tiandaren1 小时前
Selenium 4 教程:自动化 WebDriver 管理与 Cookie 提取 || 用于解决chromedriver版本不匹配问题
selenium·测试工具·算法·自动化
nbsaas-boot2 小时前
Java 正则表达式白皮书:语法详解、工程实践与常用表达式库
开发语言·python·mysql
岁忧2 小时前
(LeetCode 面试经典 150 题 ) 11. 盛最多水的容器 (贪心+双指针)
java·c++·算法·leetcode·面试·go
chao_7892 小时前
二分查找篇——搜索旋转排序数组【LeetCode】两次二分查找
开发语言·数据结构·python·算法·leetcode
陈洪奇2 小时前
注册中心学习笔记整理
笔记·学习
风无雨2 小时前
GO 启动 简单服务
开发语言·后端·golang
斯普信专业组2 小时前
Go语言包管理完全指南:从基础到最佳实践
开发语言·后端·golang
秋说4 小时前
【PTA数据结构 | C语言版】一元多项式求导
c语言·数据结构·算法
Maybyy4 小时前
力扣61.旋转链表
算法·leetcode·链表
我是苏苏4 小时前
C#基础:Winform桌面开发中窗体之间的数据传递
开发语言·c#