注册 登录
编程论坛 C++教室

有人能帮我把这个程序最后的删除函数解释一下吗?

王叫兽Joe 发布于 2014-05-24 09:09, 467 次点击
#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);
    }
}
2 回复
#2
funyh2502014-05-24 12:46
程序代码:
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;             //一直循环直到p等于第(i-1)个实例的地址(有i个Node的实例)
            j++;
        }
        q=p->next;                 //q为第i个实例的地址,该实例输出后就被销毁(Joseph())
        p->next=p->next->next;     //从新开始报数(既然下一个被销毁了所有从下下个开始)
        L=p->next;                //新的一轮中把第一个报数的那个赋给L
        return(q);
    }
}


看没高手解答故发表下个人思路
#3
一根牙签2014-05-24 22:15
链表写成这样,看起来都不舒服,
如果你是这程序的作者,应该不需要解释,
如果你不是这程序的作者,建议你找写这个程序的大神解释。

我是初学者,难以启齿。
1