C++STL容器vector的相关指令及例题圆桌问题的求解

  1. 圆桌问题求解


  • 题目已略,代码如下
  • “G”代表好人,“B”代表坏人。使用容器vector动态实现。
  • 编辑器:Xcode Version 13.1

//
//  main.cpp
//  圆桌问题
//
//  Created by Jkchou on 2022/1/16.
//

#include <iostream>
#include <vector>
using namespace std;
int main()
{
    int n, m;
    vector<int>table;
    while (cin>>n>>m) {
        table.clear();
        for (int i = 0; i < 2*n; ++i) {
            table.push_back(i);
        }
        int pos = 0;//记录坏人位置
        for (int i = 0; i < n; ++i) {//赶人
            pos = (pos + m - 1) % table.size();//环形,取余实现
            table.erase(table.begin() + pos);//删除pos处的人,table人数减1
        }
        int j = 0;
        for (int i = 0; i < 2*n; ++i) {//输出预先安排好的座位
            if(!(i % 50) && i)
                cout<<endl;
            if(j < table.size() && i == table[j]){//table内的都是好人
                j++;
                cout<<"G";
            }else{
                cout<<"B";
            }
        }
        cout<<endl;
    }
    
    return 0;
}

    2.代码分析


        vector插入或者删除某一元素时需要线性时间,即需要将该元素之后所有的元素往后移或者前移,需要O(n)的复杂度,当进行大量数据的操作时,运行效率会很低。代码中table.erase()就存在了该问题。


    3.知识拓展


        

功能例子说明
赋值a.push_back(100);在尾部添加元素
元素个数int size = a.size(); 元素个数
是否为空bool isEmpty = a.empty();判断是否为空
打印cout<<a[0]<<endl;打印第一个元素
中间插入a.insert(a.begin() + i, k);在第i个元素前面插入k
尾部插入a.push_back(8); 尾部插入元素值为8的元素
删除尾部a.pop_back();删除末尾元素
删除区间a.erase(a.begin()+i, a.begin()+j);删除区间[i, j-1]的元素
删除元素a.erase(a.begin()+2);删除第三个元素
调整大小a.resize(m);数组大小变为m
清空a.clear();清空
翻转reverse(a.begin(), a.end());reverse函数翻转vector
排序sort(a.begin(), a.end());sort排序vector

    4.备注


  1. 本文纯用作学习和分享知识,无任何商业用途,参考过部分文章与书籍,侵立删。
  2. 技术改变世界,阅读塑造人生。好好学习,天天向上。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值