hdu1276士兵队列问题

这题看题意就有队列的意思,可以开始队列掌握的太差,稍加改变,没看出来怎么应用队列。
当然没用队列的思想也可以用数组模拟这个过程
代码奉上

#include<iostream>
#include<queue>
#include<cstring>
using namespace std;
int a[5001];
int main()
{
    std::ios::sync_with_stdio(false);//减少cin读入的时间
    int T;
    cin>>T;
    memset(a,0,sizeof(a));
    while(T--)
    {
        int n;
        cin>>n;
        int sum=n;
        for(int i=1;i<=n;i++)
            a[i]=i;
        if(n<=3)
        {
            cout << "1";
            for(int i = 2; i<=n; i++)
            {
                if(a[i])
                {
                   cout << " " << a[i];
                }
            }
            cout<<endl;
            continue;
        }
        while(1)
        {
            int flag=0;
            for(int i=1;i<=n;i++)
            {
                if(a[i])
                {
                    flag++;
                }
                if(flag==2)
                {
                    a[i]=0;
                    flag=0;
                    sum--;
                }
            }
            if(sum<=3)
                break;
                flag=0;
            for(int i=1;i<=n;i++)
            {
                if(a[i])
                {
                    flag++;
                }
                if(flag==3)
                {
                    a[i]=0;
                    flag=0;
                    sum--;
                }
            }
            if(sum<=3)
                break;
        }
        cout<<"1";
        sum--;
        for(int i=2;sum;i++)
        {
            if(a[i])
            {
                cout<<" "<<a[i];
                sum--;
            }
        }
      cout<<endl;
    }
    return 0;
}

后来看了别人用到队列写这道题,感觉想法很不错,数到要出列就让它出列,不该出列的就放在队尾,并且在每个队尾加个0,控制 遍历一次,结束的条件。详细见代码

#include <iostream>  
#include <queue>  
using namespace std;  
queue<int> s;  
void cmp(int k)  
{  
 int i=1;  
 while(s.front()!=0)  
 {   
  if(i%k!=0) //把留下来的方队尾  
   s.push(s.front());  
  s.pop();i++; //去掉队首  
 }s.pop();s.push(0); //把队首的0去掉,在队尾加上0  
}  
int main (void)  
{  
 int t,n,i,j,k,l;  
 cin>>t;  
 while(t--&&cin>>n)  
 {  
  for(i=1;i<=n;i++)  
   s.push(i);s.push(0); //每次在屁股加上个0  
  i=1;  
  while(s.size()>4) //因为加上了0,所以长度小于等于4就退出  
  {  
   if(i%2==0)cmp(3); //选择数三下踢一个人还是数两下踢一个人  
   else cmp(2);  
   i++;  
  }i=0;  
  while(!s.empty()) //查看队列中是不是为空  
  {  
   if(s.front()>0) //因为队尾还有个0,这个是不用输出的但是为了清空队列,还是要pop他  
   {  
    if(i)cout<<" ";i=1;  
    cout<<s.front();  
   }  
   s.pop();  
  }cout<<endl;  
 }  
 return 0;  
}  

你可能感兴趣的:(hdu1276士兵队列问题)