zoukankan      html  css  js  c++  java
  • 约瑟夫问题(顺序表)

    # include "stdlib.h" 
    # include "stdio.h" 
    # include "conio.h" 
    # define nmax 255 
    main() 
    { 
    int i,j,k,m,n,num[nmax],*p; 
    printf("约瑟夫问题——顺序表/n输入总人数n和退出编号m:/n"); // 输入总人数,退出编号 
    scanf("%d%d",&n,&m); 
    p=num; 
    for(i=0;i<n;i++) 
    *(p+i)=i+1; // 人的位置编号从1开始到n
    i=0; // i是扫描计数器,初值置为0,最大值为n,至n后再归0 
    k=0; // k是m的计数器,至m后再归0
    j=0; // j表示被删除的总人数 
    while(j<n-1) // 当退出的人数为n-1时,剩下最后一个所求的人,循环退出 
    { 
    if(*(p+i)!=0) // 从第一个值不为0的人开始循环
    k++; 
    if(k==m) 
    { 
    *(p+i)=0; // 每次循环第m个人时,赋值为0,即标记其被删除 
    k=0; //计数器归0 
    j++; // 退出人数计数器加1 
    } 
    i++; // 扫描循环计数器加1,指向下一个人
    if(i==n) //判断一次扫描是否完成 
    i=0; // 若扫描完成,扫描循环计数器重新归0,再次重头扫描m倍数的人,并跳过那些已经被删除(即被赋0的人) 
    } 
    while(*p==0) //跳过值为0的位置编号,使p指向值不为零即最后留在圈子中的人
    p++; 
    printf("最后退出的是第%d位人/n",*p); 
    getch(); 
    } 

  • 相关阅读:
    洛谷P2805 植物大战僵尸
    洛谷P4307 球队收益
    bzoj4842 Delight for a Cat
    洛谷P2053 修车
    bzoj2561 最小生成树
    bzoj3114 LCM Pair Sum
    洛谷P4486 Kakuro
    bzoj3698 XWW的难题
    关于oracle数据库
    toString方法的用法
  • 原文地址:https://www.cnblogs.com/ituff/p/2858554.html
Copyright © 2011-2022 走看看