标题:这个程序哪儿出错,或者还应该改进哪儿
只看楼主
l376365333
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2010-8-2
结帖率:100%
 问题点数:0 回复次数:4 
这个程序哪儿出错,或者还应该改进哪儿
#include<stdio.h>
#include<malloc.h>
typedef struct linka
{
    int data;
    struct linka *next;
}link;
void reverse(link *&head)
{
    if(head==NULL)return;
    linka *pre,*cur,*ne;
    pre=head;
    cur=head->next;
    while(cur)
    {
        ne=cur->next;
        cur->next=pre;
        pre=cur;
        cur=ne;
    }
    head->next=NULL;
    head=pre;
    while(head)
    {
        printf("=%d=",head->data );
        head=head->next ;
    }
}
void main(void)
{
    link *p,*q;
    link *head=(link *)malloc(sizeof(link));
    p=head;
    for(int i=0;i<10;i++)
    {
        p->data =i+1;
        q=(link *)malloc(sizeof(link));
        p->next =q;
        p=q;
    }
    p->next =NULL;
    reverse(head);
   
}
搜索更多相关主题的帖子: 改进 
2010-12-01 18:52
l376365333
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2010-8-2
得分:0 
#include<stdio.h>
#include<malloc.h>
typedef struct linka
{
    int data;
    struct linka *next;
}link;
void reverse(link *head)
{
    if(head==NULL)return;
    linka *pre,*cur,*ne;
    pre=head;
    cur=head->next;
    while(cur)
    {
        ne=cur->next;
        cur->next=pre;
        pre=cur;
        cur=ne;
    }
    head->next=NULL;
    head=pre;
    while(head)
    {
        printf("=%d=",head->data );
        head=head->next ;
    }
}
void main(void)
{
    link *p,*q;
    link *head=(link *)malloc(sizeof(link));
    p=head;
    for(int i=0;i<10;i++)
    {
        p->data =i+1;
        q=(link *)malloc(sizeof(link));
        p->next =q;
        p=q;
    }
    p->next =NULL;
    reverse(head);
   
}
上边那个有点错
2010-12-01 19:05
qq8801103
Rank: 5Rank: 5
来 自:苏州中科大软件学院
等 级:职业侠客
威 望:1
帖 子:422
专家分:340
注 册:2009-10-8
得分:0 
请问你想得到什么样的答案,

Discuz!  
好好学习  天天向上
2010-12-02 14:58
xishui777
Rank: 2
等 级:论坛游民
帖 子:53
专家分:94
注 册:2010-8-17
得分:0 
好象是链表逆置,不过看着有点乱
2010-12-02 23:13
li_danwang
Rank: 4
来 自:鄂州
等 级:业余侠客
帖 子:112
专家分:203
注 册:2010-11-12
得分:0 
#include<stdio.h>
#include<malloc.h>
typedef struct linka
{
    int data;
    struct linka *next;
}link;

void reverse(link *&head)
{
    if(head==NULL)
        return;
    linka *pre,*cur,*ne;
    cur=head->next;
    pre=cur->next;
    cur->next=NULL;
    while(pre!=NULL)
    {
        ne=pre->next;
        pre->next=head->next;
        head->next=pre;
        pre=ne;
    }
         linka *temp=head->next;
         while(temp!=NULL)
        {
            printf("%d ",temp->data );
             temp=temp->next ;
        }
}

void main(void)
{
    link *p,*q;
    link *head=(link *)malloc(sizeof(link));
    p=head;
    for(int i=0;i<10;i++)//&Icirc;&sup2;&sup2;&aring;
    {
      
        q=(link *)malloc(sizeof(link));
        q->data =i+1;
        p->next =q;
        p=q;
    }
    p->next =NULL;
    reverse(head);

   

   
}

没事来C一下...   
2010-12-03 17:27



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




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

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