题8.15:有一个班4个学生, 5门课程。 ①求第1门课程的平均分; ②找出有两门以上课程不及格的学生, 输出他们的学号和全部课程成绩及平均成绩; ③找出平均成绩在90分以上或全部课程成绩在85分以上

本文主要是介绍题8.15:有一个班4个学生, 5门课程。 ①求第1门课程的平均分; ②找出有两门以上课程不及格的学生, 输出他们的学号和全部课程成绩及平均成绩; ③找出平均成绩在90分以上或全部课程成绩在85分以上,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

本题是谭浩强《C程序设计课后习题》题8.15。
题目:
有一个班4个学生, 5门课程。
①求第1门课程的平均分;
②找出有两门以上课程不及格的学生, 输出他们的学号和全部课程成绩及平均成绩;
③找出平均成绩在90分以上或全部课程成绩在85分以上的学生。
分别编3个函数实现以上3个要求。


以下是本篇文章正文内容,欢迎朋友们进行指正,一起探讨,共同进步。——来自考研路上的lwj

一、解题思路

思路:
本题采用二维数组来存放4个学生的5门课程,定义int a[4][5],在编写函数时,我们需要使用指针进行遍历.
大家都了解一维数组转换成指针是这样的:a[4]等价*(a+4)
那么二维数组的转换方式就是a[4][5]等价*(*(a+4)+5)
大家只要理解了这个转换方式,然后分别在所编写的函数中使用指针的方式替换数组,这道题就解出来了,求平均分和每科成绩都不难,定义两个辅助变量进行判断即可。

二、代码部分

1.引入库

代码如下(示例):

#include<stdio.h>

2.主函数部分

代码如下(示例):

int i, j;
void avg1(int a[][5], int n)
{float sum=0;for (i = 0; i < n; i++)for (j = 0; j < 5; j++)sum += *(*(a + i) + 0);printf("第一门课的平均成绩为:%f\n", sum / 5.0);
}
void fall(int a[][5], int n)
{for (i = 0; i < n; i++){int fall_count = 0;float  sum = 0;for (j = 0; j < 5; j++){if (/*a[i][j]*/*(*(a + i) + j) < 60)fall_count++;}if (fall_count <= 2)continue;printf("学号:%d有两门以上课程不及格,其全部成绩是:\n ", i + 1);for (j = 0; j < 5; j++){sum += *(*(a + i) + j) /*a[i][j]*/;printf("%d ", *(*(a + i) + j)/* a[i][j]*/);}printf("\n平均分为:%f\n", sum / 5.0);}
}
void seek(int a[][5], int n)
{/*找出平均成绩在90分以上或全部课程成绩在85分以上的学生。*/for (i = 0; i < n; i++){int fall_count = 0;float  sum = 0;for (j = 0; j < 5; j++){if (/*a[i][j]*/*(*(a + i) + j) >= 85)fall_count++;sum += *(*(a + i) + j)/*a[i][j]*/;}if (fall_count == 5 || sum / 5.0 >= 90.0)printf("学号为%d的学生平均成绩在90分以上或全部课程成绩在85分以上。\n", i + 1);}
}
int main()
{int a[4][5];printf("请输入这4名学生的5门成绩:\n");for (i = 0; i < 4; i++)for (j = 0; j < 5; j++)scanf("%d",*(a+i)+j /*&a[i][j]*/);avg1(a, 4);fall(a, 4);seek(a, 4);return 0;
}

三、执行结果

在这里插入图片描述

输出:

请输入这4名学生的5门成绩:
100 89 86 88 87
100 89 86 50 20
100 89 86 88 87
100 89 86 88 60
第一门课的平均成绩为:400.000000
学号为1的学生平均成绩在90分以上或全部课程成绩在85分以上。
学号为3的学生平均成绩在90分以上或全部课程成绩在85分以上。

这篇关于题8.15:有一个班4个学生, 5门课程。 ①求第1门课程的平均分; ②找出有两门以上课程不及格的学生, 输出他们的学号和全部课程成绩及平均成绩; ③找出平均成绩在90分以上或全部课程成绩在85分以上的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/590562

相关文章

90、k8s之secret+configMap

一、secret配置管理 配置管理: 加密配置:保存密码,token,其他敏感信息的k8s资源 应用配置:我们需要定制化的给应用进行配置,我们需要把定制好的配置文件同步到pod当中容器 1.1、加密配置: secret: [root@master01 ~]# kubectl get secrets ##查看加密配置[root@master01 ~]# kubectl get se

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

如何将一个文件里不包含某个字符的行输出到另一个文件?

第一种: grep -v 'string' filename > newfilenamegrep -v 'string' filename >> newfilename 第二种: sed -n '/string/!'p filename > newfilenamesed -n '/string/!'p filename >> newfilename

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录 在深度学习项目中,目标检测是一项重要的任务。本文将详细介绍如何使用Detectron2进行目标检测模型的复现训练,涵盖训练数据准备、训练命令、训练日志分析、训练指标以及训练输出目录的各个文件及其作用。特别地,我们将演示在训练过程中出现中断后,如何使用 resume 功能继续训练,并将我们复现的模型与Model Zoo中的

找出php中可能有问题的代码行

前言 当你发现一个平时占用cpu比较少的进程突然间占用cpu接近100%时,你如何找到导致cpu飙升的原因?我的思路是,首先找到进程正在执行的代码行,从而确定可能有问题的代码段。然后,再仔细分析有问题的代码段,从而找出原因。 如果你的程序使用的是c、c++编写,那么你可以很容易的找到正在执行的代码行。但是,程序是php编写的,如何找到可能有问题的代码行呢?这个问题就是本文要解决的问题。 背景

华为OD机试真题-学生方阵-2024年OD统一考试(E卷)

题目描述 学校组织活动,将学生排成一个矩形方阵。 请在矩形方阵中找到最大的位置相连的男生数量。这个相连位置在一个直线上,方向可以是水平的,垂直的,成对角线的或者呈反对角线的。 注:学生个数不会超过10000 输入描述 输入的第一行为矩阵的行数和列数, 接下来的 n行为矩阵元素,元素间用""分隔。 输出描述 输出一个整数,表示矩阵中最长的位

第六章习题11.输出以下图形

🌏个人博客:尹蓝锐的博客 希望文章能够给到初学的你一些启发~ 如果觉得文章对你有帮助的话,点赞 + 关注+ 收藏支持一下笔者吧~ 1、题目要求: 输出以下图形

LibSVM学习(五)——分界线的输出

对于学习SVM人来说,要判断SVM效果,以图形的方式输出的分解线是最直观的。LibSVM自带了一个可视化的程序svm-toy,用来输出类之间的分界线。他是先把样本文件载入,然后进行训练,通过对每个像素点的坐标进行判断,看属于哪一类,就附上那类的颜色,从而使类与类之间形成分割线。我们这一节不讨论svm-toy怎么使用,因为这个是“傻瓜”式的,没什么好讨论的。这一节我们主要探讨怎么结合训练结果文件