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

C++学生信息类实现
本文提供了一个使用C++实现的学生信息类定义示例,包括姓名、语文和数学成绩等属性,并展示了如何设置和获取这些属性值及计算平均分。

下面提供了类Stu的数据成员定义,和用于测试的main函数,参考如图的运行结果,完成类的定义。

/*
* Copyright (c) 2015,烟台大学计算机学院
* All right reserved.
* 作者:邵帅
* 文件:Demo.cpp
* 完成时间:2015年03月21日
* 版本号:v1.0
*/
#include<iostream>
#include<string>
using namespace std;
class Stu
{
private:
    string name;	//学生姓名
    float chinese;	//语文成绩
    float math;		//数学成绩
    //接下去写
public:
    void show();
    void setName(string);
    void setStudent(string,int,int);
    string getName();
    int average();
};
void Stu::show()
{
    cout<<"Name:"<<name<<endl;
    cout<<"Score:"<<chinese<<" "<<math<<endl;
    cout<<"Average:"<<average()<<"  ";
    cout<<"Sum:"<<chinese+math<<endl;
}
void Stu::setName(string na)
{
    name=na;
}
void Stu::setStudent(string na,int ch,int ma)
{
    name=na;
    chinese=ch;
    math=ma;
}
string Stu::getName()
{
    return name;
}
int Stu::average()
{
    return (chinese+math)/2;
}
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");//重新置p1对象的名字
    s1.show();
    cout<<"s1.Name: "<<s1.getName()<<endl;//打印对象的名字
    cout<<"s1.average: "<<s1.average()<<endl;//打印对象的成绩
    return 0;
}


运行结果:



@ Mayuko


转载于:https://www.cnblogs.com/mayuko/p/4567530.html

<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; ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值