查看全部128种考试
1
2
3
4
5
6
7
8
9
10
萧雨  
【字体: 二级C上机模拟试题及答案(3)
二级C上机模拟试题及答案(3)
djks.exam8.com 来源:考试吧(Exam8.com) 更新:2004-8-16 21:43:00 计算机等级考试 考试论坛
设有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+1个至倒数第i个元素依次向前移动一个
位置;
(3) 重复第(2)步直至圈中只剩下p[1]为止。
注意: 部分源程序存放在PROG1.C中。
请勿改动主函数main()和输出数据函数WriteDat()的内容。

/*参考答案*/

#include
#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) ;
fprintf(fp, "%4d", p) ;
if(i % 10 == 0) {
printf("\n") ;
fprintf(fp, "\n") ;
}
}
fclose(fp) ;
}

转帖于:计算机等级考试_考试吧
文章搜索  
看了本文的网友还看了:
计算机等级考试权威辅导教材: 订书电话:010-62168566  更多>>>
网友评论
昵 称: *  评 分: 1分 2分 3分 4分 5分
标题:   匿名发表    (共有条评论)查看全部评论>>
版权声明 -------------------------------------------------------------------------------------
  如果计算机等级考试网所转载内容不慎侵犯了您的权益,请与我们联系,我们将会及时处理。如转载本计算机等级考试网内容,请注明出处。
关于本站  网站声明  广告服务  联系方式  付款方式  站内导航  客服中心  友情链接  考试论坛  网站地图
Copyright © 2004-2008 考试吧计算机等级考试网 All Rights Reserved    
中国科学院研究生院权威支持(北京) 电 话:010-62168566 传 真:010-62192699
百度大联盟黄金认证  十佳网络教育机构  经营许可证号:京ICP060677