stl::list(标准库的list使用)

作者在 2011-12-13 22:55:00 发布以下内容
标题:1、Stl::list模版使用
时 限:1000 ms
内存限制:10000 K
总时限:3000 ms
描述:

完成学生类版的定义报包含如下信息:姓名 学号 年龄

输入:

学生个数(比如为N)

N条学生记录(格式为:1 张平一 902418 19,这是其中1表示按顺序插入,张平一是学生姓名,902418是整数学号,19是年龄)

插入学生的个数(比如为M)

M条插入学生的记录(格式为:17 张平一 902418 19,其中17表示插入到整个记录表的第17位(从0开始,数组下标为16,若17>数组长度,输出Insert Error),张平一是学生姓名,902418是整数学号,19是年龄)

K条删除学生的记录

K个记录的数组位置(从0开始,如果没有这个位置,输出Delete Error)

 

输出:

插入、删除错误

全部学生记录

Reverse

逆向输出全部学生记录

DelSame

删除相同学号的学生记录后的输出(删除时,要保留此时—反转后所有相同的学号的第一个人,请看示例张充直和孙小雪的去留)

Sort

按学号降序输出学生记录

输入样例:

5

1 张平一 902418 19

1 刘浩 902433 21

1 刘磊 902411 21

1 白平一 902425 20

1 张充直 902429 21

3

1 孙小雪 902429 20

3 张潮 902415 21

13 赵洗星 902435 20

3

18 5 6

输出样例:

Insert Error

Delete Error

Delete Error

Name 张平一 Num 902418  Age 19

Name 孙小雪 Num 902429  Age 20

Name 刘浩   Num 902433  Age 21

Name 张潮   Num 902415  Age 21

Name 刘磊   Num 902411  Age 21

Name 张充直 Num 902429  Age 21

Reverse

Name 张充直 Num 902429  Age 21

Name 刘磊   Num 902411  Age 21

Name 张潮   Num 902415  Age 21

Name 刘浩   Num 902433  Age 21

Name 孙小雪 Num 902429  Age 20

Name 张平一 Num 902418  Age 19

DelSame

Name 张充直 Num 902429  Age 21

Name 刘磊   Num 902411  Age 21

Name 张潮   Num 902415  Age 21

Name 刘浩   Num 902433  Age 21

Name 张平一 Num 902418  Age 19

Sort

Name 刘磊   Num 902411  Age 21

Name 张潮   Num 902415  Age 21

Name 张平一 Num 902418  Age 19

Name 张充直 Num 902429  Age 21

Name 刘浩   Num 902433  Age 21

提示:请注意,插入和删除时输入的位置从零开始
#include <list>
#include <string>
#include <iostream>

using namespace std;

class StudentRecord
{
private:
    string name;
    int num;
    int age;

public:
    StudentRecord(string _name = "", int _num = 0, int _age = 1)
    {
        name = _name;
        num = _num;
        age = _age;
    }
    string GetName()
    {
        return name;
    }
    int GetNum()
    {
        return num;
    }
    int GetAge()
    {
        return age;
    }
    friend ostream& operator<<(ostream &out, const StudentRecord &stu)
    {
        out << "Name " << stu.name << " Num " << stu.num << " Age " << stu.age;
        return out;
    }

    virtual ~StudentRecord() {}
};
list<StudentRecord>::iterator operator +(list<StudentRecord>::iterator const it,int move_length)
{
    list<StudentRecord>::iterator that=it;
    for(int i=0; i<move_length; i++)
    {
        that++;
    }
    //if(that==it) cout<<"指针相同"<<endl;
    
//else cout<<"指针不同"<<endl;
    return that;
}
bool compare(StudentRecord a,StudentRecord b)
{
    if(a.GetNum()<=b.GetNum()) return true;
    else return false;
}

int main()
{
    list<StudentRecord> stu_list;
    int n;
    cin >> n;
    int  no_relative, num, age;
    string name;
    for (int i = 0; i < n; ++i)
    {
        cin >> no_relative;
        cin >> name >> num >> age;
        stu_list.push_back(StudentRecord(name, num, age));
    }
    cin >> n;
    int locate;
    for (int i = 0; i < n; ++i)
    {
        cin >> locate;
        cin >> name >> num >> age;
        if (locate > (signed)stu_list.size()-1)
        {
            cout << "Insert Error" << endl;
        }
        else
        {
            list<StudentRecord>::iterator it = stu_list.begin();
            it=it+locate;
            stu_list.insert(it, StudentRecord(name, num, age));
        }

    }
    cin >> n;
    for (int i = 0; i < n; ++i)
    {
        cin >> locate;
        //cout<<locate<<endl;
        
//cout<<stu_list.size();
        if (locate>(signed) stu_list.size()-1||locate < 0 )
        {
            cout << "Delete Error" << endl;
        }
        else
        {
            list<StudentRecord>::iterator it = stu_list.begin();
            it=it+locate;
            cout<<"Delete right"<<endl;
            cout<<*it<<endl;
            stu_list.erase(it);
        }

    }
    for (list<StudentRecord>::iterator it = stu_list.begin(); it != stu_list.end(); it++)
    {
        cout << *it << endl;
    }
    stu_list.reverse();
    cout << "Reverse"<< endl;;
    for (list<StudentRecord>::iterator it = stu_list.begin(); it != stu_list.end(); it++)
    {
        cout << *it << endl;
    }
    for (list<StudentRecord>::iterator it_locate = stu_list.begin(); it_locate != stu_list.end(); it_locate++)
    {
        list<StudentRecord>::iterator it = it_locate+1;
        for (; it != stu_list.end(); it++)
        {
            if (it->GetNum() == it_locate->GetNum())
            {
                it = stu_list.erase(it);
                it--;
            }
        }
    }
    cout << "DelSame" << endl;
    for (list<StudentRecord>::iterator it = stu_list.begin(); it != stu_list.end(); it++)
    {
        cout << *it << endl;
    }
    stu_list.sort(compare);
    cout << "Sort" << endl;
    for (list<StudentRecord>::iterator it = stu_list.begin(); it != stu_list.end(); it++)
    {
        cout << *it << endl;
    }
    return 0;
}
 
c++ | 阅读 1655 次
文章评论,共0条
游客请输入验证码
浏览70048次