救济金发放The Dole QueueUVA 133

来源:互联网 发布:深孔钻编程 编辑:程序博客网 时间:2024/05/17 06:56
  1. #include<cstdio>
  2. int main(){
  3.     int a[25];
  4.     int N,k,m;
  5.     while(scanf("%d%d%d",&N,&k,&m)==3 && N){
  6.         for(int i=N-1;i>=0;i--){      //倒序输入
  7.             a[N-i-1]=i+1;
  8.         }
  9.         int leave=N;
  10.          int k1=N-1;     //逆序
  11.          int m1=0;       //顺序
  12.         while(leave){    //当留下0人时退出循环
  13.             for(int i=0;i<k;i++){
  14.                 if(a[k1=(N+k1)%N]==0)i--;
  15.                 k1--;
  16.             }
  17.             k1++;

  18.             for(int i=0;i<m;i++){
  19.                 if(a[m1=(m1%N)]==0)i--;
  20.                 m1++;
  21.             }
  22.             m1--;

  23.             if(m1!=k1){
  24.                 leave-=2;
  25.                 if(leave)
  26.                 printf("%3d%3d,",a[k1],a[m1]);
  27.                 else printf("%3d%3d",a[k1],a[m1]);
  28.                 a[k1]=0;a[m1]=0;
  29.             }
  30.             else {
  31.                 leave--;
  32.                 if(leave)
  33.                 printf("%3d,",a[k1]);
  34.                 else printf("%3d",a[k1]);
  35.                 a[k1]=a[m1]=0;
  36.             }
  37.         } 
  38.         printf("\n");
  39.     }
  40.     return 0;
  41. }
0 0