?? 3.cpp
字號(hào):
#include<stdio.h>
#include<malloc.h>
#define NULL 0
typedef struct node{
int data;
int num;
node *next;
}node,*queue;
typedef struct{
queue front;
queue rear;
}sqQueue;
int initqueue(sqQueue &q){//構(gòu)造隊(duì)列
q.front=q.rear=(queue)malloc(sizeof(node));
if(!q.front)return 0;
q.front->next=NULL;
return 1;
}
void destroyqueue(sqQueue &q){//銷毀隊(duì)列
while(q.front){
q.rear=q.front->next;
free(q.front);
q.front=q.rear;
}
}
int enqueue(sqQueue &q,int e,int num){//插入元素e為Q的新的隊(duì)尾元素
node *p=NULL;
p=(queue)malloc(sizeof(node));
if(!p)return 0;
p->data=e;
p->num=num;
p->next=NULL;
q.rear->next=p;
q.rear=p;
q.rear->next=q.front->next;
return 1;
}
void main(){
int n=0,m=0,a=1,b=0;
sqQueue l;
node *p,*q;
p=NULL;
q=NULL;
if(initqueue(l)==0)printf("分配存儲(chǔ)空間失敗");
printf("請(qǐng)輸入人數(shù)n=");
scanf("%d",&n);
printf("請(qǐng)輸入初始計(jì)數(shù):");
scanf("%d",&m);
printf("請(qǐng)輸入每個(gè)人的密碼(以空格分開):");
for(int i=0;i<n;i++){
scanf("%d",&b);
int j=i+1;
if(!enqueue(l,b,j)){
printf("輸入失敗,請(qǐng)重新輸入!");
i--;
}
}
q=p=l.front->next;
while(a<=n){
for(int i=1;i<m;i++){
q=p;
p=p->next;
}
m=p->data;
printf("第%d個(gè)出列的是%d\n",a,p->num);
a++;
q->next=p->next;
free(p);
p=q->next;
}
}
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -