@( 2021-05-05 21:40 采纳率: 33.3%
浏览 96
已采纳

#include<stdio.h> int main() { int j=0,i,M,N,rest

#include int main() { int j=0,i,M,N,rest; long long a[10000001]={0}; scanf("%d %d",&N,&M); rest=N; for(i=1;rest!=1;i++) { if(a[i]==0) j++; if(j==M) { a[i]=M; j=0; rest--; } if(i==N) i=0; } for(i=1;i<=N;i++) if(a[i]==0) printf("%d\n",i); return 0; } 这个数组不能定义很大,所以不知道怎么办了,求大佬指导!!!
  • 写回答

2条回答 默认 最新

  • benbenli 2021-05-07 20:05
    关注

    搜索 约瑟夫环问题 可以找到链接 算法科普:什么是约瑟夫环-五分钟学算法 ,里面详细讲解了几种算法。数组求解和循环链表会堆溢出,递归求解会栈溢出。迭代法最好。下面代码运行通过了。

    #include <stdio.h>
    
    int Joseph(int n,int m)
    {
        int i;
        int x,y;
        if(n <= 1 || m <= 1)
            return -1;
        if(m % 2 == 0)
            y = 1;
        else
            y = 2;
    
        for(i = 3; i <= n; i++)
        {
            x = (y-1 + m) % i + 1;
            y = x;
        }
        return y;
    }
    int main()
    {
        int n,m,x;
        printf("输入 n 和 m :\n");
        scanf("%d %d",&n,&m);
        x=Joseph(n,m);
        printf("最后一个数为:%d\n",x);
        return 0;
    }
    
    
    // Output
    输入 n 和 m :                                                                                                                                                                        
    10000000 3                                                                                                                                                                         
    最后一个数为:3093025   

    附注:求赞助积分和C币。加入CSDN将近20年了。最近几年忙小孩没登录。刚才搜索到一本电子书想下载,需要20积分/C币。赞助多少都可以。多谢。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 ffmpeg如何安装到虚拟环境
  • ¥188 寻找能做王者评分提取的
  • ¥15 matlab用simulink求解一个二阶微分方程,要求截图
  • ¥30 乘子法解约束最优化问题的matlab代码文件,最好有matlab代码文件
  • ¥15 写论文,需要数据支撑
  • ¥15 identifier of an instance of 类 was altered from xx to xx错误
  • ¥100 反编译微信小游戏求指导
  • ¥15 docker模式webrtc-streamer 无法播放公网rtsp
  • ¥15 学不会递归,理解不了汉诺塔参数变化
  • ¥15 基于图神经网络的COVID-19药物筛选研究