标题:链表倒置
取消只看楼主
zd123
Rank: 2
等 级:论坛游民
帖 子:43
专家分:33
注 册:2009-9-4
结帖率:70%
已结贴  问题点数:20 回复次数:1 
链表倒置
#include"stdio.h"
#include"malloc.h"
#include"stdlib.h"
#define SIZE sizeof(snode)
typedef struct student
{
    int num;
    struct student *next;
}snode;
snode *create();                           //创建链表
void print(snode *head);                    //打印链表
void invert(snode *&head);                    //为什么是  *&  呢?????????????而不是 snode *head
void main(void)
{
    int m,k;
    snode *head,head1;
    head=create();   
    print(head);
    printf("\n\n\n");
    printf("链表逆置后结果为:\n");
    invert(head);
    print(head);
}
snode *create()
{
    snode *head,*p,*q;
    p=q=(snode *)malloc(sizeof(SIZE));
    head=(snode *)malloc(sizeof(SIZE));
    int n=0,num1;
    FILE *fp;
    fp=fopen("D:\\qq.txt","r");
    fscanf(fp,"%d",&num1);
    p->num=num1;
    while(!feof(fp))              
    {
        n++;
        if(n==1)
            head=p;           
        else
            q->next=p;
        q=p;
        p=(snode *)malloc(sizeof(SIZE));
        fscanf(fp,"%d",&num1);
        p->num=num1;
    }
    q->next=NULL;
    return (head);
}
void print(snode *head)
{
    snode *p;
    p=head;                 //带头结点
    while(p!=NULL)
    {
        printf("%6d",p->num);
        p=p->next;
    }
}
void invert (snode *&head)           //为什么是  *&  呢?????????????而不是 snode *head
{
    snode *p,*q,*r;
    p=head;
    q=p->next;
    while(q!=NULL)
    {
        r=q->next;
        q->next=p;
        p=q;
        q=r;
    }
    head->next=NULL;
    head=p;
}
搜索更多相关主题的帖子: 链表 倒置 
2009-09-04 11:14
zd123
Rank: 2
等 级:论坛游民
帖 子:43
专家分:33
注 册:2009-9-4
得分:0 
大家帮忙看看了,问题在注释里
2009-09-06 09:25



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




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

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