![]() ![]() |
|
二级B上级模拟试题及答案(3) | |
作者:佚名 文章来源:不详 点击数 更新时间:2008/4/18 14:49:22 文章录入:杜斌 责任编辑:杜斌 | |
|
|
编制函数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) ; } |
|
![]() ![]() |