| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 598 人关注过本帖
标题:帮下忙.. 编了个大体 有几个小问题 求帮忙!
只看楼主 加入收藏
古城荆棘王
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2011-9-20
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:1 
帮下忙.. 编了个大体 有几个小问题 求帮忙!
#include<string>
#include<cmath>
#include<iostream>
#include<cstdlib>
using namespace std;
class Course
{
private:
    friend class Systemgrade;
    Course *next;
    string subject;    //课程名称
    double credit;        //学分
    double score;         //成绩
    string quality;    //成绩性质
    double GPA;         //绩点?
public:
    //创建构造与析构函数
    Course(string sub="",double cre=0,double s=0,string q="");   
    Course(const Course& temp)
    {
        subject=temp.subject;
        credit=temp.credit;
        score=temp.score;
        quality=temp.quality;
        GPA=temp.GPA;
    }
    ~Course() {}
    void output();
    string getSubject() const  {return subject;}      
    int getCredit() const {return credit;}
    double getScore() const  {return score;}
    string getQuality() const   {return quality;}
    double getGPA() const {return GPA;}
    //计算绩点
   
};


Course::Course(string sub,double cre,double s,string q)   
{
    subject=sub;
    credit=cre;
    score=s;
    quality=q;
    if(score-50>=1e-5)
        GPA=(score-50)*0.1;
    else
        GPA=0;
    if(quality=="优秀") GPA=4.0;
    if(quality=="良好") GPA=3.0;
    if(quality=="中等") GPA=2.0;
    if(quality=="及格") GPA=1.0;
    if(quality=="不及格") GPA=0.0;
}

void Course::output()
{
    cout<<subject<<"  "<<credit<<"  "<<GPA<<endl;
}
class Systemgrade
{
    Course *first;
    double ave;
    int tot;
public:
    Systemgrade()
    {
        first=new Course;
        first->next=NULL;
    }
    void add(string sub="",double cre=0,double s=0,string q="");
    void OUT();
    void Add();
    void Ave();
};
void Systemgrade::OUT()
{
    cout<<"   科目  学分  绩点"<<endl;
    Course *p=first->next;
    while(p!=NULL)
    {
        p->output();
        p=p->next;
    }
    cout<<"平均学分绩点"<<endl;
    cout<<ave<<endl;
}

void Systemgrade::add(string sub,double cre,double s,string q)
{
    Course *p=new Course(sub,cre,s,q);
    if(first->next==NULL)
    {
        first->next=p;
    }
    else
    {
        Course *q=first->next;
        first->next=p;
        p->next=q;
    }
}

void Systemgrade::Ave()
{
    Course *p=first->next;
    double sum1=0,sum2=0;
    while(p!=NULL)
    {
        sum1+=p->credit*p->GPA;
        sum2+=p->credit;
        p=p->next;
    }
    ave=sum1/sum2;
}

void Systemgrade::Add()
{
    cout<<"请输入成绩相关信息,按   科目  学分   成绩(等级)"<<endl;
    string sub;
    double cre;
    char a[20];
    cin>>sub>>cre>>a;
    if(a[0]>='0' && a[0]<='9')
    {
        double s=atoi(a);          //将字符串里的数字强制转换成整形数
        add(sub,cre,s);
    }
    else
    {
        string ss=a;
        add(sub,cre,0,ss);
    }
}



int main()
{
//    freopen("in.txt","r",stdin);
    Systemgrade System;
    int menu,sonmenu;
repeat0:
    cout<<"显示所有信息,请按:1"<<endl;
    cout<<"添加信息,请按:2"<<endl;
    cin>>menu;
    switch(menu)
    {
    case 1:
        System.OUT();
        cout<<"返回主菜单,请按:0"<<endl;
        cout<<"直接退出,请按:-1"<<endl;
        cin>>sonmenu;
        if(sonmenu==-1)
            goto repeat11;
        if(sonmenu==0)
            goto repeat0;
    case 2:
repeat1:
        System.Add();
        cout<<"继续,添加请按:1"<<endl;
        cout<<"返回主菜单,请按:0"<<endl;
        cin>>sonmenu;
        if(sonmenu==1)
            goto repeat1;
        if(sonmenu==0)
            goto repeat0;
    }
repeat11:
    return 0;
}



   


上面的能运行 输入课程名、学分和成绩,但是要根据  平均学分绩点(GPA)=    ∑(课程学分数×绩点数×K)
    ________________________________________       ∑课程学分数
计算相应的积点   还要判断所获得的绩点是否合格,能给出相应的结果提示 这三个不会 求帮忙
搜索更多相关主题的帖子: private include public double friend 
2011-09-23 14:20
bhu_wll
Rank: 3Rank: 3
来 自:北京
等 级:论坛游侠
帖 子:70
专家分:167
注 册:2011-9-8
收藏
得分:20 
哪里不会?怎么不会?直接说出来,

努力对待生活
2011-09-29 11:03
快速回复:帮下忙.. 编了个大体 有几个小问题 求帮忙!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.033852 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved