c - 如何创建一个计算最高平均成绩的函数?
问题描述
函数int getMax(student *students, int entry_size)应该计算所有学生的最高成绩。这里的student是结构体,*students是数组,entry_size 已经可以使用如下所示的函数找到。getMax函数的技巧是它应该使用递归;包含数据的文件格式如下:
Name Surname ID Grade
Name Surname ID Grade
...
我已经完成了部分代码,它扫描并返回一组学生:
#include <stdio.h>
#include <stdlib.h>
typedef struct {
char firstName[30], secondName[30];
int ID;
int grade;
} student;
typedef struct {
int ID;
int avgGrade;
} topThreeAvg;
student *readStudents(char *fileName, int* entry_size, int *all_ids, int* studentSize){
/*
all_ids is an array for counting the amount of grades per student. studentSize is the actual number of students (for example, in students1.txt it is 2)
*/
FILE *openedFile = fopen(fileName, "r");
if(openedFile == NULL){
printf("Cannot open a file");
exit (0);
}
char entrySize[10];
fscanf(openedFile, "%[^\n]", entrySize);
int numberOfEntries = atoi(entrySize);
*entry_size = numberOfEntries;
student *students;
if ( NULL == ( students = malloc(numberOfEntries * sizeof *students))) {
printf ("Error with memory allocation");
exit (0);
}
int i;
for(i=0; i < numberOfEntries; i++){
if (4 != fscanf(openedFile, "%s %s %d %d"
, students[i].firstName
, students[i].secondName
, &students[i].ID
, &students[i].grade)) {
exit (0);
}
}
return students;
}
我试图实现这个功能,但它给出了非常大的数字:
int max_in(student *students, int entry_size){
int curr_val = students->grade;
if (entry_size == 1) {
return curr_val;
}
int max_in_rest = max_in(&students->ID+1, entry_size-1);
return curr_val > max_in_rest ? curr_val : max_in_rest;
}
如何使函数递归并在所有学生中找到最高分?
解决方案
尝试如下。
int max(int x, int y){
return x > y ? x : y;
}
int max_in(student *students, int entry_size){
if (entry_size <= 0){
return -1;
}
else {
return max(students[entry_size-1].grade, max_in(students, entry_size-1))
}
}
推荐阅读
- sql - 添加两个查询一起使用
- python - 使用 Python 提取准确的价格数据,如在 Excel 表中看到的那样,而不用四舍五入 Python 端的值
- multithreading - Async/Await 仍然阻塞 UI?
- c - 为什么我会收到“free(): invalid pointer”的错误?
- django - 在自己的服务器上托管 Django Rest 框架
- java - Hibernate 如何映射列?
- c# - 如何缓慢缩放相机并使其平滑?
- c# - 'AsyncEnumerableReader' 在枚举值时达到了配置的最大缓冲区大小
- python - 尽管格式正确,熊猫仍无法推断时间序列频率?
- bash - 如何检查基于busybox的Unix系统中是否没有传递命令行参数?