nefu 1632 周末舞会-队列
熟悉语法题,不难
#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 取牌游戏-队列

熟练语法题,不难
#include
using namespace std;
int main()
{
int m,n,k,p,i;
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 报数-队列

经典的约瑟夫环问题,用队列轻松加愉快,果然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)
{
if(j%m==0)q.pop();
else
{
q.push(q.front());
q.pop();
}
j++;
}
cout<<q.front();
return 0;
}
nefu 1635 酒桌游戏-队列

同样也是约瑟夫环问题,多了结构体,也就是结构体+队列
#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]);
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


用做丑数的方法做
#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;
};
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];
q.push({beginx,0});
while(!q.empty())
{
node tmp=q.front();q.pop();
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;
int c;
};
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())
{
a[q.front().c]--;
if(a[q.front().c]==0)cnt--;
q.pop();
}
printf("%d\n",cnt);
}
return 0;
}