【C++】约瑟夫环(数组+链表)

基于数组:

复制代码
#include<iostream>
#include<cstring>
#include<cstdlib>
using namespace std;

int *a;
int *vis;

bool isfull(int m)
{
    for(int i=0;i<m;i++)
    {
        if(!vis[i])
            return false;
    }
    return true;
}

void john(int m,int n)
{
    int p=m-1;
    while(!isfull(m))
    {
        int left=n;
        while(left>0)
        {
            p=(p+1)%m;
            if(!vis[p])
            {
                left--;
            }
            cout<<vis[p];
        }
        vis[p]=1;
        cout<<":"<<a[p]<<endl;
    }
}

int main()
{
    int m,n;
    while(scanf("%d %d",&m,&n)&&m&&n)
    {
        a=(int *)malloc(m*sizeof(int));
        for(int i=0;i<m;i++)
            a[i]=i+1;
        vis=(int *)malloc(m*sizeof(int));
        for(int i=0;i<m;i++)
            vis[i]=0;
        
        john(m,n);
    }
    
    return 0;
}
复制代码

 

基于链表:

复制代码
#include<iostream>
using namespace std;

struct node
{
    int data;
    node *next;
};

node *head;

void john(int m,int n)
{
    node *p=head;
    node *r=head->next;
    while(r->next!=head)
        r=r->next;
    while(p)
    {
        if(p->next==p)
        {
            cout<<p->data<<endl;
            return ;
        }
        int left=n;
        while(left>1)
        {
            left--;
            p=p->next;
            r=r->next;
        }
        cout<<p->data<<endl;
        r->next=p->next;
        delete p;
        p=r->next;
    }
}

int main()
{
    int m,n;
    while(scanf("%d %d",&m,&n)&&m&&n)
    {
        head=new node();
        head->data=1;
        node *p=head;
        int a=2;
        while(a<=m)
        {
            node *t=new node();
            t->data=a;
            p->next=t;
            p=p->next;
            a++;
        }
        p->next=head;//形成环 
        /*
        p=head->next;
        while(p!=head)
        {
            cout<<p->data<<endl;
            p=p->next;
        }
        */
        john(m,n);
    }
    
    return 0;
}
复制代码

 

运行示例:

 

 

tz@HZAU

2019/3/12

posted on   tuzhuo  阅读(299)  评论(0编辑  收藏  举报

编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示