就业数据资源平台
当前位置:首页 > C语言程序设计
二级C语言程序设计上机考试习题集57

★☆题目57(无忧id 109  出圈题)
设有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) ;


此题的另一种形式(实际上机的考试题)
 设有n个人围坐一圈并按顺时针方向从1到n编号,从第s个人开始进行1到m的报数, 报数到第m个人, 此人出圈, 再从他的下一个人重新开始1到m的报数,如此进行下去直到所有的人都出圈为止。现要求按出圈次序,给出这n个人的顺序表p。请考生编制函数josegh()实现此功能并调用函数writedat()把编号按照出圈的顺序输出到out.dat文件中。
注意:第1个出圈的编号存放在p[0]中,第2个出圈的编号存放在p[1]中,直至第n个出圈的编号存放在p[n-1]中。
     设 n = 100, s = 1, m = 10进行编程。
     注意: 部分源程序存放在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,q[100];
  for(i=0;i<n;i++)  q[i]=0;
  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;
   }
/*由于上面的解法是倒着存放出圈数,以下采用两个循环的是将数组p中的数据倒过来以实现题意要求,即:第1个出圈的编号存放在p[0]中,第2个出圈的编号存放在p[1]中,直至第n个出圈的编号存放在p[n-1]中。*/
   for(i=0,j=n-1;i<n,j>=0;i++,j--) /*也可改为for(i=0,j=n-1;i<n;i++,j--) */
     q[j]=p[i];
   for(i=0;i<n;i++)
     p[i]=q[i];
}
void main()
{
  m = m ;
  n = n ;
  s = s ;
  josegh() ;
  writedat() ;
}
void writedat(void) /*注意两种题中此函数的区别*/
{
  int i, j = 0 ;
  file *fp ;
  fp = fopen("out.dat", "w") ;
  for(i = 0 ; i <= n - 1 ; i++) {
    printf("%4d ", p[i]) ;
    fprintf(fp, "%4d", p[i]) ;
    j++ ;
    if(j % 10 == 0) {
      printf("\n") ;
      fprintf(fp, "\n") ;
    }
  }
  fclose(fp) ;
}
就业数据资源平台