vector的使用-Hdu 4841

Posted jingshixin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vector的使用-Hdu 4841相关的知识,希望对你有一定的参考价值。

圆桌问题

Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)
Total Submission(s): 6252    Accepted Submission(s): 2380


Problem Description
圆桌上围坐着2n个人。其中n个人是好人,另外n个人是坏人。如果从第一个人开始数数,数到第m个人,则立即处死该人;然后从被处死的人之后开始数数,再将数到的第m个人处死……依此方法不断处死围坐在圆桌上的人。试问预先应如何安排这些好人与坏人的座位,能使得在处死n个人之后,圆桌上围坐的剩余的n个人全是好人。
 

 

Input
多组数据,每组数据输入:好人和坏人的人数n(<=32767)、步长m(<=32767);
 

 

Output
对于每一组数据,输出2n个大写字母,‘G’表示好人,‘B’表示坏人,50个字母为一行,不允许出现空白字符。相邻数据间留有一空行。
 

 

Sample Input
2 3 2 4
 

 

Sample Output
GBBG BGGB
 

这个题思路其实很简单,就是把坏人踢出去,好人留下来,用vector可以很好的实现,这是数组很难实现的操作,但是用vector做起来就很简单

代码:

#include <bits/stdc++.h>

using namespace std;

int main()
{
    vector<int>table;
    int n,m;
    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);
        } 
        int j = 0;
        for(int i = 0;i < 2*n; i++){
            if(!(i%50) && i)
                cout<<endl;
            if(j<table.size() && i==table[j]){
                j++;
                cout<<"G";
            }
            else
                cout<<"B";
        }
        cout<<endl<<endl;
    }
    return 0;
}

 

 
 

以上是关于vector的使用-Hdu 4841的主要内容,如果未能解决你的问题,请参考以下文章

hdu 4841 用stl::vector解决约瑟夫问题

HDU4841 圆桌问题(vector的妙用)

hdu4841_圆桌问题

圆桌问题(hdu4841)

hdu4841 圆桌问题

HDU 4841 : 圆桌问题