高手啊 求救求救啊帮我用c语言编写个先进先出的算法 急需啊 30

我继续这个程序我们才刚学c语言就开始了系统结构这课也不会希望大家帮小弟一忙啊这两个我完全看不懂啊有没有稍微简单点的啊... 我继续这个程序 我们才刚学c语言 就开始了系统结构这课也不会 希望大家帮小弟一忙啊
这两个我完全看不懂啊 有没有稍微简单点的啊
展开
 我来答
绝对封魂
2007-06-20 · 超过44用户采纳过TA的回答
知道答主
回答量:198
采纳率:0%
帮助的人:0
展开全部
呵,是出圈问题吧

设有n个人围坐一圈并按顺时针方向从1到n编号,从第s个人开始进行1到m的报数,报数到第m个人,此人出圈,再从他的下一个人重新开始1到m的报数,如此进行下去直到所有的人都出圈为止。现要求按出圈次序,每10人一组,给出这n个人的顺序表。编制函数Josegh()实现此功能并调用函数WriteDat()把结果p输出

到文件JOSE.OUT中。

设 n = 100, s = 1,m = 10。

(1) 将1到n个人的序号存入一维数组p中;

(2) 若第i个人报数后出圈,则将p[i]置于数组的倒数第i个位置上,而原来第i+1个至倒数第i个元素依次向前移动一个位置;

(3) 重复第(2)步直至圈中只剩下p[1]为止。

注意:部分源程序存放在文件prog1.c中。

请勿改动主函数main()和输出数据函数WriteDat()的内容。

#include <stdio.h>

#define N 100

#define S 1

#define M 10

int p[100], n, s, m ;

void WriteDat(void) ;

void Josegh(void)

{ int i,j,s1,w;

s1=s;

for(i=1; i<=n; i++)

p[i-1]=i;

for(i=n; i>=2; i--)

{ s1=(s1+m-1)%i;

if(s1==0) s1=i;

w=p[s1-1];

for(j=s1; j<i; j++)

p[j-1]=p[j];

p[i-1]=w;

}

}

void main()

{

m = M ;

n = N ;

s = S ;

Josegh() ;

WriteDat() ;

}

void WriteDat(void)

{

int i ;

FILE *fp ;

fp = fopen("jose.out", "w") ;

for(i = N - 1 ; i >= 0 ; i--) {

printf("%4d ", p[i]) ;

fprintf(fp, "%4d", p[i]) ;

if(i % 10 == 0) {

printf("\n") ;

fprintf(fp, "\n") ;

}

}

fclose(fp) ;

}
回答者:镠金 - 秀才 二级 11-16 00:21

提问者对于答案的评价:
嘿嘿太谢谢了~学习了,努力中
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
soyboydoy
2007-06-20 · TA获得超过241个赞
知道小有建树答主
回答量:402
采纳率:0%
帮助的人:0
展开全部
...
楼上的...

应该是队列:
int tag;
int head;
int queue[100];

int inqueue(n)
int n;
{
queue[head++]=n;
if(head>99) head=0;
}
int outqueue()
{
int tmp;
tmp=queue[tag++];
if(tag>99) tag=0;
return tmp;
}

以上就是队列的两个基本操作,依次是入队和出队.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式