九度OJ 题目1188:约瑟夫环

题目1188:约瑟夫环

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:689

解决:303

题目描述:

    N个人围成一圈顺序编号,从1号开始按1、2、3......顺序报数,报p者退出圈外,其余的人再从1、2、3开始报数,报p的人再退出圈外,以此类推。
    请按退出顺序输出每个退出人的原序号。

输入:

包括一个整数N(1<=N<=3000)及一个整数p。

输出:

测试数据可能有多组,对于每一组数据,
按退出顺序输出每个退出人的原序号。

样例输入:
7 3
样例输出:
3 6 2 7 5 1 4
来源:
2003-2005年华中科技大学计算机研究生机试真题

/*********************************
*   日期:2013-2-14
*   作者:SJF0115
*   题号: 九度OJ 题目1188:约瑟夫环
*   来源:http://ac.jobdu.com/problem.php?pid=1188
*   结果:AC
*   来源:2003-2005年华中科技大学计算机研究生机试真题
*   总结:先将所有人进行编号,如果被删除就将其编号设置为0。 循环直到队列中只剩0个人
**********************************/
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
	int n,i,j,people,index,remain,ID;
	int DeleteID[3001];
	while(scanf("%d %d",&people,&ID) != EOF){
		int Flag[3001] = {0};//标记1为删除
		index = 0;
		remain = people;
		while(remain >= 1){
			for(j = 0;j < people;j++){
				//对没有标记为1的报数	
				if(Flag[j] == 0){
					//报数
					index ++;
					//报ID者退出圈外
					if(index == ID){
						//退出圈外
						Flag[j] = 1;
						//重新报数
						index = 0;
						DeleteID[remain-1] = j+1;
						remain --;
					}//if
				}//if
			}//for
		}//while
			
		//输出每个退出人的原序号
		for(j = people-1;j >= 0;j--){
			if(j == 0){
				printf("%d\n",DeleteID[j]);
			}
			else{
				printf("%d ",DeleteID[j]);
			}
		}
	}//while
    return 0;
}

约瑟夫环:点击打开链接

你可能感兴趣的:(华科)