c++stl之queue(队列)oj题目练习

nefu 1632 周末舞会-队列c++stl之queue(队列)oj题目练习_第1张图片

熟悉语法题,不难

#include 

using namespace std;

int main()
{
    int m,n,k;
    cin>>n>>m>>k;
    queue<int>q1,q2;
    for(int i=1;i<=n;i++)q1.push(i);
    for(int i=1;i<=m;i++)q2.push(i);
    while(k--)
    {
        cout<<q1.front()<<" "<<q2.front()<<endl;
        q1.push(q1.front());
        q2.push(q2.front());
        q1.pop();
        q2.pop();
    }
    return 0;
}

nefu 1633 取牌游戏-队列

c++stl之queue(队列)oj题目练习_第2张图片

熟练语法题,不难

#include 

using namespace std;

int main()
{
    int m,n,k,p,i;//k为纸牌数,n为人数,m为好牌数,p为移到最后的纸牌数
    cin>>n>>k>>p;
    queue<int>q;
    int a[10005];
    for(i=1;i<=k;i++)q.push(i);
    i=1;
    int ans=0;
    while(!q.empty())
    {



        if(i%n==0){a[ans]=q.front();ans++;} q.pop();
        i++;
        for(int j=0;j<p;j++)
        {
            q.push(q.front());
            q.pop();
        }
    }
    sort(a,a+ans);
    for(int j=0;j<ans;j++)cout<<a[j]<<endl;
    return 0;
}

nefu 1634 报数-队列

c++stl之queue(队列)oj题目练习_第3张图片

经典的约瑟夫环问题,用队列轻松加愉快,果然stl就是好用

#include 

using namespace std;

int main()//用队列做这个环真是太简单了,以前啥都没学的时候觉得真的难
{
    int n,m;
    cin>>n>>m;
    queue<int>q;
    for(int i=1;i<=n;i++)q.push(i);
    int j=1;
    while(q.size()!=1)//不是!q.empty()
    {
        if(j%m==0)q.pop();
        else
        {
            q.push(q.front());
            q.pop();
        }
        j++;
    }
    cout<<q.front();
    return 0;
}

nefu 1635 酒桌游戏-队列

c++stl之queue(队列)oj题目练习_第4张图片

同样也是约瑟夫环问题,多了结构体,也就是结构体+队列

#include 

using namespace std;
struct node
{
    int num;
    string name;
}p[1001];

int main()
{
    int n,m,t;
    cin>>n>>m>>t;
    queue<node>q;
    for(int i=1;i<=n;i++)
    {
        cin>>p[i].name;
        p[i].num=i;
    }
    for(int i=1;i<=n;i++)q.push(p[i]);//这里应该从1起push
    for(int j=0;j<m-1;j++)
    {
        q.push(q.front());
        q.pop();
    }
    for(int j=t;q.size()!=1;j++)
    {
        if(j%7==0||j%10==7)q.pop();
        else
        {
            q.push(q.front());
            q.pop();
        }
    }

    printf("%s\n",q.front().name.c_str());
    return 0;
}

nefu 1662 Blash数集-队列-set

c++stl之queue(队列)oj题目练习_第5张图片
c++stl之queue(队列)oj题目练习_第6张图片

用做丑数的方法做

#include 
using namespace std;
const int N=1e5+10;
int n,p2,p3,a[N];
int main()
{
    ios::sync_with_stdio(false);
    cin>>a[1]>>n;
    p2=1,p3=1;
    for(int i=2;i<=n;i++)
    {
        a[i]=min(2*a[p2]+1,3*a[p3]+1);
        if(a[i]==2*a[p2]+1)p2++;
        if(a[i]==3*a[p3]+1)p3++;
    }
    printf("%d\n",a[n]);
    return 0;
}

nefu 1663 关系网络-队列

bfs

#include 
using namespace std;
int a[1001][1001];
int n,beginx,beginy,endx,endy,newx,newy;
int dir[4][2]={{1,0},{-1,0},{0,-1},{0,1}};
struct node
{
    int x,cnt;//cnt记录步数
};
queue<node>q;
int main()
{
    ios::sync_with_stdio(false);
    cin>>n>>beginx>>endx;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
        cin>>a[i][j];//以1、1为起点输入二维字符数组
    q.push({beginx,0});//先把起点入队,开始时cnt=0
    while(!q.empty())//开始搜索,用队列实现BFS,当队列为空还未到终点,则无法达到终点(求最短步数实际上已经保证了一定能到终点)
    {
        node tmp=q.front();q.pop();//按队列顺序依次取出队首tmp
        if(tmp.x==endx){printf("%d\n",tmp.cnt-1);break;}//找到终点,输出答案,搜索结束

        for(int i=1;i<=n;i++)
        {
            if(a[tmp.x][i]){
            newx=i;
            if(newx>=1&&newx<=n&&a[tmp.x][i]==1)
            {a[tmp.x][newx]=0;a[newx][tmp.x]=0;q.push({newx,tmp.cnt+1});}//新节点入队,并且走到新节点的步数是原节点的步数加一
            }
        }
    }
    return 0;
}

洛谷 P2058 海港

#include 

using namespace std;
int a[300010],n,n1,x,t1,cnt;
struct sa
{
    int t;//time
    int c;//country
};
int main()
{
    queue<sa>q;
    scanf("%d",&n);
    for(int i=0;i<n;i++)
    {
        scanf("%d%d",&t1,&n1);
        for(int i=0;i<n1;i++)
        {
            scanf("%d",&x);
            q.push({t1,x});
            if(a[x]==0)cnt++;
            a[x]++;
        }
        while(t1-q.front().t>=86400&&!q.empty())//!q.empty()很重要
        {
            a[q.front().c]--;
            if(a[q.front().c]==0)cnt--;
            q.pop();
        }
        printf("%d\n",cnt);
    }
    return 0;
}

你可能感兴趣的:(c++stl之queue(队列)oj题目练习)