第三周项目四 考了语文数学的学生

本文介绍了一个使用C++实现的学生信息管理系统,包括学生姓名、语文数学成绩、平均成绩和总成绩的显示与修改。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

main.cpp

/*
*Copyright (c) 2014,烟台大学计算机学院void change(int a[8][8]);
*All rights reserved.
*文件名称:main.cpp
*作者:苏强
*完成日期:2015年3月23日
*版本号:v1.0
*
*问题描述:输出考试学生的信息
*输入描述:无
*程序输出:姓名、语文数学成绩、平均成绩和总成绩
*/
#include <iostream>
#include "stu.h"
using namespace std;
int main()
{
    Stu s1,s2;
    s1.setStudent("Lin daiyu",98,96);
    s2.setStudent("Jia baoyu",90,88);
    s1.show();
    s2.show();
    s1.setName("Xue baochai");
    s1.show();
    cout<<"s1.Name:"<<s1.getName()<<endl;
    cout<<"s1.average:"<<s1.average()<<endl;
    return 0;
}


stu.h

#ifndef STU_H_INCLUDED
#define STU_H_INCLUDED
#include <cstring>
using namespace std;
class Stu
{
private:
    string name;
    float chinese;
    float math;
public:
    float average();
    float sum();
    void setStudent(string n,float c,float m);
    void setName(string p);
    void show();
    string getName();
};
#endif // STU_H_INCLUDED


stu.cpp

#include <iostream>
#include "stu.h"
#include <cstring>
using namespace std;
float Stu::average()
{
    return (chinese+math)/2;
}
float Stu::sum()
{
    return chinese+math;
}
void Stu::setStudent(string n,float c,float m)
{
    name=n;
    chinese=c;
    math=m;
}
void Stu::setName(string p)
{
    name=p;
}
void Stu::show()
{
    cout<<"Name:"<<name<<'\n'<<"Score:"<<chinese<<'\t'<<math<<'\n';
    cout<<"avreage:aa"<<average()<<'\t'<<"sum:"<<sum()<<endl;
    cout<<endl;
}
string Stu::getName()
{
    return name;
}


 

考虑怎么写头文件

<think>我们面对的是一个查询需求:找出语文成绩高于数学成绩的学生信息及其对应的课程分数。 在数据库中,通常会有学生表(包含学生信息)和成绩表(包含各科成绩)。假设我们有两张表: 学生表(Students):包含学生ID(student_id)、姓名(name)等字段。 成绩表(Scores):包含学生ID(student_id)、课程(course)、分数(score)等字段。 由于成绩表中,每个学生的不同课程成绩是分开存储的(即一行一个课程的成绩),我们需要将同一个学生语文数学成绩放在一行进行比较。 方法:使用自连接(self-join)或子查询(subquery)来将语文数学的成绩合并到一行,然后比较。 假设成绩表中课程名称分别为:'语文'和'数学'。 我们可以这样设计查询: 方案1:使用自连接 将成绩表分别作为语文成绩表和数学成绩表,然后通过学生ID连接,最后比较语文成绩是否大于数学成绩。 方案2:使用聚合函数(如MAX配合CASE语句)将语文数学成绩转置为列,然后进行比较。 这里我们提供两种常见的SQL写法: 写法1(自连接): SELECT s.student_id, s.name, chinese.score AS chinese_score, math.score AS math_score FROM Students s JOIN Scores chinese ON s.student_id = chinese.student_id AND chinese.course = '语文' JOIN Scores math ON s.student_id = math.student_id AND math.course = '数学' WHERE chinese.score > math.score; 写法2(使用CASE语句进行行转列,然后比较): SELECT s.student_id, s.name, MAX(CASE WHEN sc.course = '语文' THEN sc.score END) AS chinese_score, MAX(CASE WHEN sc.course = '数学' THEN sc.score END) AS math_score FROM Students s JOIN Scores sc ON s.student_id = sc.student_id WHERE sc.course IN ('语文', '数学') GROUP BY s.student_id, s.name HAVING chinese_score > math_score; 注意:第二种方法中,我们使用了GROUP BY按学生分组,然后使用聚合函数(这里用MAX或MIN都可以,因为每个学生每个课程只有一条记录)将语文数学成绩转成列。然后使用HAVING子句来比较。 两种方法都可以达到目的,但需要注意: - 第一种方法要求每个学生都必须有语文数学成绩,否则连接会失败(即不会出现在结果中)。 - 第二种方法同样要求每个学生都有两门课的成绩,因为WHERE条件只选了这两门课,然后分组后每个学生只有两行,转成两列。如果某个学生缺了一门课,那么其中一门就会是NULL,而比较NULL和数值会得到NULL(即条件不满足)。所以两种方法都只适用于有完整两门成绩的学生。 如果需要包含只有语文成绩而没有数学成绩的学生(此时语文成绩大于数学成绩,因为数学成绩为NULL),那么需要调整。但通常比较成绩时,我们只虑两门成绩都有的情况。 因此,我们按照常规情况,只查询两门成绩都存在的学生。 下面给出具体的SQL语句(以写法1为例,因为更直观):</think>### 语文成绩高于数学成绩的学生查询方法 以下提供两种SQL实现方案(假设表结构为:**学生表**含`student_id, name`,**成绩表**含`student_id, course, score`): --- #### **方案1:自连接查询** 通过连接同一学生语文数学的成绩记录进行比较: ```sql SELECT s.student_id, s.name AS 学生姓名, chi.score AS 语文成绩, math.score AS 数学成绩 FROM Students s JOIN Scores chi ON s.student_id = chi.student_id AND chi.course = '语文' JOIN Scores math ON s.student_id = math.student_id AND math.course = '数学' WHERE chi.score > math.score; ``` **说明**: - 需确保每个学生均有两条记录(语文数学成绩) - 结果包含学生ID、姓名及两科分数 --- #### **方案2:行转列聚合查询** 使用`CASE`语句将行数据转为列后比较: ```sql SELECT student_id, MAX(CASE WHEN course = '语文' THEN score END) AS 语文成绩, MAX(CASE WHEN course = '数学' THEN score END) AS 数学成绩 FROM Scores WHERE course IN ('语文', '数学') GROUP BY student_id HAVING 语文成绩 > 数学成绩; ``` **说明**: - 适用于成绩存储为多行场景 - `HAVING`子句直接比较聚合后的分数 --- ### 关键注意事项 1. **缺失值处理**:若学生某科目,方案1会排除该生(因连接失败),方案2会返回`NULL`(需添加`AND score IS NOT NULL`过滤) 2. **性能优化**:对`scores`表的`course`和`student_id`字段建立索引可加速查询 3. **扩展性**:如需返回学生姓名,在方案2中需连接`Students`表: ```sql SELECT s.name, t.* FROM ( SELECT student_id, ... FROM Scores GROUP BY student_id HAVING ... ) t JOIN Students s ON t.student_id = s.student_id; ``` ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值