高手啊 求救求救啊帮我用c语言编写个先进先出的算法 急需啊
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高手啊 求救求救啊帮我用c语言编写个先进先出的算法 急需啊相关的知识,希望对你有一定的参考价值。
我继续这个程序 我们才刚学c语言 就开始了系统结构这课也不会 希望大家帮小弟一忙啊
这两个我完全看不懂啊 有没有稍微简单点的啊
设有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
提问者对于答案的评价:
嘿嘿太谢谢了~学习了,努力中 参考技术B ...
楼上的...
应该是队列:
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;
以上就是队列的两个基本操作,依次是入队和出队.
mvc3.0 项目部署到iis7.0 怎么部署啊做了设置也还是提示不列出目录403之类 讨厌死了高手大侠求救。。。。
参考技术A dsadasdas 参考技术B iis7上装了mvc3没有?以上是关于高手啊 求救求救啊帮我用c语言编写个先进先出的算法 急需啊的主要内容,如果未能解决你的问题,请参考以下文章
谁能帮我做下这道C语言编程题,明天就要交了,好心人帮帮忙,谢谢了~~~~求救呀·~~~
将C语言循环部分优化,改成线性汇编或者C的都行!~~高手求救