首页 > 其他 > 详细

CCF学生排队

时间:2020-03-07 12:44:03      阅读:45      评论:0      收藏:0      [点我收藏+]

这题如果考虑考虑用数组折腾会非常麻烦,如果想到用vector的insert函数和erase函数就会非常舒服的模拟出来。vt.erase(it)之后it就变成了野指针,所以要用it=erase(it),这样it就会自动指向下一个元素。

#include<cstdio>
#include<iostream>
#include<vector>
#include<algorithm>
#include<string.h>
using namespace std;
int main()
{
    int n, k;
    cin >> n;
    getchar();
    cin >> k;
    vector<int>vt;
    int i;
    for (i = 0; i < n; i++)
    {
        vt.push_back(i+1);
    }
    int s, p;
    vector<int>::iterator it = vt.begin();
    while (k--)
    {
        cin >> s >> p;
        for (it=vt.begin(); it != vt.end(); it++)
        {
            if(*it==s)
            {
                it = vt.erase(it);
                vt.insert(it + p, s);
                break;
            }
        }
    }
    for (it = vt.begin(); it != vt.end(); it++)
    {
        cout << *it <<  ;
    }
    cout << endl;
}

 

CCF学生排队

原文:https://www.cnblogs.com/legendcong/p/12390085.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!