编程练习(3)

一.选择题

第一题:

函数传参的两个变量都是传的地址,而数组名c本身就是地址,int型变量b需要使用&符号,因此答案为A

第二题:

本题考察const修饰指针变量,答案为A,B,C,D

第三题:

注意int 型变量 i 是全局变量, 本题答案为=D

第四题:

**考察运算符优先级和结合性:**我们需要分析这个代码中的赋值运算符和算术运算符的优先级和结合性。赋值运算符是用来给变量赋值的符号,例如等号(=),加等(+=),减等(-=),等等。算术运算符是用来进行数值计算的符号,例如加法(+),减法(-),乘法(*),除法(/),取模(%),等等。赋值运算符和算术运算符有不同的优先级,表示它们的执行顺序。优先级高的运算符先执行,优先级低的运算符后执行。如果有多个相同优先级的运算符,那么就要看它们的结合性,表示它们的执行方向。结合性可以是从左到右(L->R),也可以是从右到左(R->L)。
为了得到结果,我们需要按照赋值运算符和算术运算符的优先级和结合性来计算表达式(a+=a-=a*a)的值。根据C语言中的规则 ,赋值运算符和算术运算符的优先级和结合性如下:

因此表达式求值顺序为:(a+=(a-=(a*a))) ,最终得到表达式结果为-12 ,最终答案为D

第五题:

本题简单,D选项中循环判断条件始终为假因此不会进入for循环, 答案为D

二.编程题:

第一题:

cpp 复制代码
#include<stdio.h>
int main() {
	//输入要输入的整数个数:
	int n;
	scanf("%d", &n);
	int i = 0;
	//负数个数
	int negative_number = 0;
	//正数个数
	int positive_number = 0;
	//正数的和
	int sum = 0;
	//正数平均值
	int average;
	//输入整数并放入数组
	int arr[n];
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr[i]);
	}

	int j = 0;
	for (j = 0; j < n; j++)
	{
		if (arr[j] < 0)
		{
			negative_number++;
		}
		if (arr[j] > 0)
		{
			sum = sum + arr[j];
			positive_number++;
		}
	}

	printf("%d ", negative_number);
    //判断是否除负数意外全为0
	if (positive_number != 0)
		printf("%.1f", (float)sum / positive_number);
	else
		printf("%.1f", 0);

}

以上便是今日练习心得,感谢大家三连支持

相关推荐
白羊by8 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖10 小时前
最大最小值降采样算法的优化
c++·算法
glimix10 小时前
Word-Pop:使用C语言开发打单词游戏
c语言·游戏
white-persist12 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
FL162386312912 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
独小乐12 小时前
019.ADC转换和子中断|千篇笔记实现嵌入式全栈/裸机篇
linux·c语言·驱动开发·笔记·嵌入式硬件·mcu·arm
baizhigangqw13 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
C雨后彩虹13 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_250114 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-13012314 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法