数据结构—线性实习题目(二)

学生信息管理

#include <iostream>
using namespace std;
#include <string>
 
 
struct LinkNode {
    int s_num;
    string s_name;
    double s_garde1;
    double s_garde2;
    double s_garde3;
    double jun_zhi;
    LinkNode* link;
    LinkNode() {
        link = NULL;
    }
    LinkNode(int num, string name, double n1, double n2, double n3) {
        s_num = num;
        s_name = name;
        s_garde1 = n1;
        s_garde2 = n2;
        s_garde3 = n3;
        jun_zhi = (n1 + n2 + n3) / 3;
        link = NULL;
    }
};
 
template <class T>
class LineList {
public:
    int length;
    LinkNode* first;
public:
    LineList() {}
    LineList(int n) {
        length = n;
        first = new LinkNode();
        LinkNode* current = first;
        for (int i = 0; i < length; i++) {
            int num;
            string name;
            double n1, n2, n3;
            cin >> num;
            cin >> name;
            cin >> n1 >> n2 >> n3;
            LinkNode* newnode = new LinkNode(num,name,n1,n2,n3);
            current->link = newnode;
            current = newnode;
        }
    }
 
 
    void Sort() {
        LinkNode* current = first;
        LinkNode* p;
        LinkNode* q;
        for (p = current->link; p != NULL; p = p->link)
        {
            for (q = p->link; q != NULL; q = q->link) {
                if (p->jun_zhi < q->jun_zhi)
                {
                    int tmp = q->s_num;
                    q->s_num = p->s_num;
                    p->s_num = tmp;
                    string tmp2 = q->s_name;
                    q->s_name = p->s_name;
                    p->s_name = tmp2;
                    double tmp3 = q->s_garde1;
                    q->s_garde1 = p->s_garde1;
                    p->s_garde1 = tmp3;
                    double tmp4 = q->s_garde2;
                    q->s_garde2 = p->s_garde2;
                    p->s_garde2 = tmp4;
                    double tmp5 = q->s_garde3;
                    q->s_garde3 = p->s_garde3;
                    p->s_garde3 = tmp5;
                    double tmp6 = q->jun_zhi;
                    q->jun_zhi = p->jun_zhi;
                    p->jun_zhi = tmp6;
                }
            }
        }
    }
 
    void Print() {
        LinkNode* current = first;
        for (int i = 1; i <= length; i++) {
            current = current->link;
            cout.precision(2);
            cout << current->s_num << " " << fixed
                << current->s_name << " " << fixed
                << current->s_garde1 << " " << fixed
                << current->s_garde2 << " " << fixed
                << current->s_garde3 << " " << fixed
                << current->jun_zhi << " " << i << endl;
        }
        cout << endl;
    }
 
};
 
int main() {
    int n;
    cin >> n;
    LineList<double> L(n);
    L.Sort();
    L.Print();
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

511511511

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值