标题:有人能帮我把约瑟夫函数调用的最后一个删除函数解释一下吗?
只看楼主
王叫兽Joe
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2014-5-23
结帖率:33.33%
已结贴  问题点数:20 回复次数:2 
有人能帮我把约瑟夫函数调用的最后一个删除函数解释一下吗?
#include<iostream>
using namespace std;
struct Node
{
    int data;
    Node *next;
};
Node *CreateList(Node *L,int &n);
void Joseph(Node *L,int n,int m);
Node *DeleteList(Node *&L,int i,Node *q);
int main()
{
    Node *L;
    L=NULL;
    int n,m;
    cout<<"请输入人数N:";
    cin>>n;
    if(n<1) {cout<<"请输入正整数!";}
    else
    {
        cout<<"请输入密码M:";
        cin>>m;
        if(m<1) {cout<<"请输入正整数!";}
        else
        {
            L=CreateList(L,n);
            Joseph(L,n,m);
        }
    }
    system("pause");
    return 0;
}
Node *CreateList(Node *L,int &n)
{
    Node *q;
    for(int i=1;i<=n;i++)
    {
        Node *p;
        p=new Node;
        p->data=i;
        p->next=NULL;
        if(i==1)
            L=q=p;
        else
        {
            q->next=p;
            q=q->next;
        }
    }
    q->next=L;
    if(L!=NULL)
        return(L);
    else
        cout<<"尾指针异常!"<<endl;
}
void Joseph(Node *L,int n,int m)
{
    cout<<"\n出列顺序:\n";
    for(int i=1;i<n;i++)
    {
        Node *q=new Node;
        q=DeleteList(L,m,q);
        cout<<"号数:"<<q->data<<endl;
        delete(q);
    }
    cout<<"号数:"<<L->data<<endl;
    delete L;
}
Node *DeleteList(Node *&L,int i,Node *q)
{
    Node *p,*m;
    p=L;
    if(i==1)
    {
        m=p->next;
        while (m->next!=L)
            m=m->next;
        m->next=p->next;
        q=L;
        L=m->next;
        return q;
    }
    else
    {
        int j=1;
        while(j<i-1)
        {
            p=p->next;
            j++;
        }
        q=p->next;
        p->next=p->next->next;
        L=p->next;
        return(q);
    }
}
搜索更多相关主题的帖子: include 输入密码 约瑟夫 正整数 
2014-05-24 08:50
砖家的谎言
Rank: 12Rank: 12Rank: 12
等 级:禁止访问
威 望:30
帖 子:693
专家分:3898
注 册:2013-12-6
得分:0 
这是用的C++写的,我一直用C,C++的一些编写代码习惯看着不习惯,来学习的

我不是砖家,要努力成为砖家。
2014-05-24 08:56
张小齊
Rank: 2
等 级:论坛游民
帖 子:14
专家分:46
注 册:2014-5-23
得分:20 
兴许把i改成m更好理解
Node *DeleteList(Node *&L,int m,Node *q)
{
    Node *p,*r;//***** r是需要删除的结点。
    p=L;
    if(m==1)//***密码为1,逐个删除
    {
        r=p->next;
        while (r->next!=L)
            r=r->next;
        r->next=p->next;
        q=L;
        L=r->next;
        return q;
    }
    else
    {
        int j=1;
        while(j<m-1)
        {
            p=p->next;
            j++;
        }
        q=p->next;    //删除报数为m的
        p->next=p->next->next;
        L=p->next;
        return(q);
    }
}
代码命名要好理解,多写注释。。。
2014-05-24 15:06



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-431977-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.193506 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved