java 约瑟夫问题的数组解法

 我来答
匿名用户
2015-05-16
展开全部
public class 约瑟夫问题 {

  public static void main(String[] args) {
    int[] a = new int[13];
    int start = 0;
    int n = 5;
    while (圈里是否还有人(a)) {
      start = 出圈(start, n, a);
    }
  }

  private static int 出圈(int start, int n, int[] a) {
    int i = start;
    while (n > 0) {
      while (a[i] == 1) {
        i = (i + 1) % a.length;
      }
      i = (i + 1) % a.length;
      n--;
    }
    i = (i + a.length - 1) % a.length;
    a[i] = 1;
    System.out.println(i);
    return i;
  }

  private static boolean 圈里是否还有人(int[] a) {
    for (int i = 0; i < a.length; i++) {
      if (a[i] == 0)
        return true;
    }
    return false;
  }
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式