lina181 2015-05-23 04:40 采纳率: 0%
浏览 1845
已采纳

反转单向链表,C语言,运行出错

#include
#include

/* run this program using the console pauser or add your own getch, system("pause") or input loop */

typedef struct LNode{
int node;
struct LNode *next;
} LNode,*LinkList;

LinkList Head_Node()
{
LinkList head;
head=(LinkList)malloc(sizeof(LNode));
if(head==NULL)
{
printf("空间分配失败\n");
return head;
}
head->next=NULL;
return head;
}

int CreateList(LinkList head)
{
int data;
char c;
LinkList p,q;
q=head;
printf("请输入数据:");
do
{
scanf("%d",&data);
c=getchar();
p=(LinkList)malloc(sizeof(LNode));
if(p==NULL)
{
printf("空间分配失败\n");
return -1;
}
p->node=data;
p->next=q->next;
q->next=p;
q=p;
}
while(c!='\n');
return 0;
}

LinkList Reverse(LinkList head)
{
LinkList p,q,r;
p=head;
q=head->next;
head->next=NULL;
if(q->next!=NULL)
{
r=q->next;
q->next=p;
p=q;
q=r;
}
q->next=p;
head->next=q;
return head;
}

void Output(LinkList head)
{
LinkList p;
p=head->next;
while(p)
{
printf("%d ",p->node);
p=p->next;
}
}

int main()
{
LinkList head;
head=Head_Node();
CreateList(head);
Reverse(head);
Output(head);
system("pause");
return 0;
}

  • 写回答

6条回答 默认 最新

  • 关注
     #include <stdio.h>
    #include <stdlib.h>
    
    /* run this program using the console pauser or add your own getch, system("pause") or input loop */
    
    typedef struct LNode{
        int node;
        struct LNode *next;
    } LNode,*LinkList;
    
    LinkList Head_Node()
    {
        LinkList head;
        head=(LinkList)malloc(sizeof(LNode));
        if(head==NULL)
        {
            printf("空间分配失败\n");
            return head;
        }
        head->node = -1;
        head->next=NULL;
        return head;
    }
    
    int CreateList(LinkList head)
    {
        int data;
        char c;
        LinkList p,q;
        q=head;
        printf("请输入数据:");
        do
        {
            scanf("%d",&data);
            c=getchar();
            if(-1 == data)
                break;
    
            p=(LinkList)malloc(sizeof(LNode));
            if(p==NULL)
            {
                printf("空间分配失败\n");
                return -1;
            }
            p->node=data;
            p->next=q->next;
            q->next=p;
            q=p;
        }
        //while(c == 10);//如果是这样你希望以什么方式退出(这里的10代表'\n')?
        while(1);
        return 0;
    }
    
    //你的翻转函数有逻辑问题
    LinkList Reverse(LinkList head)
    {
        LinkList p,q,r;
    
        p = head->next;
        q = p->next;
        p->next = NULL;
    
        while(q->next!=NULL)
        {
            r=q->next;
            q->next=p;
            p=q;
            q=r;
        }
        q->next=p;
        head->next = q;
    
        return head;
    }
    
    void Output(LinkList head)
    {
        LinkList p;
        p=head->next;
        while(p != NULL)
        {
            printf("%d ",p->node);
            p=p->next;
        }
        putchar(10);
    }
    
    int main()
    {
        LinkList head;
        head=Head_Node();
        CreateList(head);
        Output(head);
        Reverse(head);
        printf("*********************************************************\n");
        Output(head);
        //system("pause");
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥30 vmware exsi重置后登不上
  • ¥15 易盾点选的cb参数怎么解啊
  • ¥15 MATLAB运行显示错误,如何解决?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题
  • ¥20 yolov5自定义Prune报错,如何解决?
  • ¥15 电磁场的matlab仿真
  • ¥15 mars2d在vue3中的引入问题
  • ¥50 h5唤醒支付宝并跳转至向小荷包转账界面