【C语言】每日一题(半月斩)——day3

目录

一,选择题

[1.已知函数的原型是: int fun(char b[10], int *a);](#1.已知函数的原型是: int fun(char b[10], int *a);)

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

[3、以下程序的输出结果为( )](#3、以下程序的输出结果为( ))

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

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

二,编程题

1.记负均正

2.旋转数组的最小数字


一,选择题

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个例外:

  1. sizeof(数组名),这里的数组名表示的整个数组,计算的是整个数组的大小,单位是字节。
  2. &数组名,这里的数组名表示整个数组,取出的是整个数组的地址。

除此之外,所有遇到的数组名都是数组首元素的地址。

注:数组传参的本质是指针,传递的是数组首元素地址

但是形参也可以是数组接收,也可以指针接收。

正确答案:A

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

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

解析:

考察的是对const的理解

const修饰指针

修饰指针有两种方法

counst int* p ;

int * counst p;

  • const 放在的左边

限制的指针指向的内容,也就是说: 不能通过指针来修改指针指向的内容

但是指针变量是可以修改的,也就是指针指向其他变量的

  • const 放在的右边

限制的是指针变量本身,指针变量不能再指向其他对象

但是可以通过指针变量来修改指向的内容

正确答案:ABCD

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

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: * * *

解析:

本题考察的是,转义字符和全局变量

转义字符:

'\t' 代表为水平制表符 ,简单来说就是在键盘上按了TAB的效果,也可以理解为缩进符

全局变量

作用域为整个程序生命周期与主函数相同,只有程序结束,它才会销毁

在进入prt()后出来时 i 被修改成了8,然后进行主函数的条件调整表达式; i++;i变成了9;

不满足主函数的条件判断表达式,推出循环

正确答案:A

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

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

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

解析:

考察:运算符优先级,操作符(复合赋值符)的理解

查看操作符优先级表可以得知,'*'乘法的优先级高于赋值操作符;

所以先算后面的 a-=a*a -> a=a-a*a; a=-6;

再算前面的 a+=a-> a=a+a; a=-12;

正确答案:D

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

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

解析:

考察:循环条件判断

C语言中规定:0为假,非0为真;

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

正确答案:D

二,编程题

1.记负均正

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

0即不是正整数,也不是负数,不计入计算。如果没有正数,则平均值为0。

记负均正------牛客网

int main()
{
	int n = 0;
	int arr[1000];
	scanf("%d", &n);
	int i = 0;
	//往数组输入元素
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr[i]);
	}
	//输出负数
	int num = 0;	//记录负数个数
	//正整数的平均值
	double pos = 0;	//记录正整数个数
	double temp = 0;
	double sum = 0;	//平均数
	int zero = 0;  //记录0的个数
	for (i = 0; i < n; i++)
	{
		if (arr[i] < 0)
		{
			num++;
		}
		else if (arr[i] == 0)
			zero++;
		else
		{
			temp = temp + arr[i];
			pos++;
		}
	}
	if (zero == n)
	{
		printf("%d 0.0\n",num);
	}
	else {
    {
        sum = temp / pos;
	printf("%d %.1lf",num, sum);
    }
    }
	return 0;
}

2.旋转数组的最小数字

有一个长度为 n 的非降序数组,比如[1,2,3,4,5],将它进行旋转,即把一个数组最开始的若干个元素搬到数组的末尾,变成一个旋转数组,比如变成了[3,4,5,1,2],或者[4,5,1,2,3]这样的。请问,给定这样一个旋转数组,求数组中的最小值。

旋转数组的最小值------牛客网

static int min = 10000;
int minNumberInRotateArray(int* rotateArray, int rotateArrayLen ) {
    // write code here
    int i = 0;
    for(i = 0; i < rotateArrayLen;i++)
    {
        if(rotateArray[i]< min)
        {
            min = rotateArray[i];
        }
    }
    return min;
}
相关推荐
SpongeG31 分钟前
数据结构第三周做题总结_链表
数据结构·算法·链表
ImomoTo31 分钟前
HarmonyOS学习(十三)——数据管理(二) 关系型数据库
数据库·学习·harmonyos·arkts·鸿蒙
everyStudy32 分钟前
前端五种排序
前端·算法·排序算法
小珑也要变强32 分钟前
队列基础概念
c语言·开发语言·数据结构·物联网
醉竺36 分钟前
【高阶数据结构】二叉搜索树的插入、删除和查找(精美图解+完整代码)
数据结构
little redcap2 小时前
第十九次CCF计算机软件能力认证-乔乔和牛牛逛超市
数据结构·c++·算法
wang_book3 小时前
Gitlab学习(007 gitlab项目操作)
java·运维·git·学习·spring·gitlab
AI原吾3 小时前
掌握Python-uinput:打造你的输入设备控制大师
开发语言·python·apython-uinput
机器视觉知识推荐、就业指导3 小时前
Qt/C++事件过滤器与控件响应重写的使用、场景的不同
开发语言·数据库·c++·qt
毕设木哥3 小时前
25届计算机专业毕设选题推荐-基于python的二手电子设备交易平台【源码+文档+讲解】
开发语言·python·计算机·django·毕业设计·课程设计·毕设