编程练习(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);

}

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

相关推荐
pusue_the_sun12 分钟前
数据结构——栈和队列oj练习
c语言·数据结构·算法··队列
大锦终13 分钟前
【算法】模拟专题
c++·算法
Dontla1 小时前
Makefile介绍(Makefile教程)(C/C++编译构建、自动化构建工具)
c语言·c++·自动化
Xの哲學1 小时前
Perf使用详解
linux·网络·网络协议·算法·架构
奶黄小甜包1 小时前
C语言零基础第18讲:自定义类型—结构体
c语言·数据结构·笔记·学习
想不明白的过度思考者1 小时前
数据结构(排序篇)——七大排序算法奇幻之旅:从扑克牌到百亿数据的魔法整理术
数据结构·算法·排序算法
小七rrrrr1 小时前
动态规划法 - 53. 最大子数组和
java·算法·动态规划
code小毛孩1 小时前
leetcodehot100 矩阵置零
算法
一支闲人1 小时前
C语言相关简单数据结构:双向链表
c语言·数据结构·链表·基础知识·适用于新手小白
何妨重温wdys1 小时前
矩阵链相乘的最少乘法次数(动态规划解法)
c++·算法·矩阵·动态规划