| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 493 人关注过本帖
标题:大哥大姐们,帮帮忙,一个链表问题,输出错误!!!
只看楼主 加入收藏
tan2010
Rank: 2
等 级:论坛游民
帖 子:66
专家分:71
注 册:2011-10-13
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:4 
大哥大姐们,帮帮忙,一个链表问题,输出错误!!!
#include<stdio.h>
#include<stdlib.h>
#define NULL 0
struct student{
    int data;
    struct student *next;
};

int main()
{
    struct student *pnew,*head;
    int i,num;
    pnew=(struct student *)malloc(sizeof(struct student));//开辟首结点
    pnew=head;
   
   
    for(i=0;i<=4;i++)//输入五个学号
    {
       scanf("%d",&num);
       pnew->data=num;
       pnew->next=(struct student *)malloc(sizeof(struct student));//开辟下一个结点
           if(i==4)pnew->next=NULL;
           else pnew=pnew->next;

    }
    pnew=head;
    while(pnew!=NULL)
    {
      printf("%d",pnew->data);
      pnew=pnew->next;
      printf("\n");
    }   
     return 1;  
}//创建一个链表!!!
搜索更多相关主题的帖子: include 大哥大 
2011-11-01 23:25
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
收藏
得分:10 
回复 楼主 tan2010
int main(){    struct student *pnew,*head;    int i,num;    pnew=(struct student*)malloc(sizeof(struct student));//开辟首结点    pnew=head;//这句错了,应该是head=pnew;

总有那身价贱的人给作业贴回复完整的代码
2011-11-01 23:35
tan2010
Rank: 2
等 级:论坛游民
帖 子:66
专家分:71
注 册:2011-10-13
收藏
得分:0 
太谢谢了!!!
2011-11-02 12:35
cui_gf
Rank: 1
等 级:新手上路
帖 子:7
专家分:6
注 册:2011-9-1
收藏
得分:0 
#include<stdio.h>
#include<stdlib.h>
#define NULL 0
struct student{
    int data;
    struct student *next;
};

int main()
{
    struct student *pnew,*head,*temp;//head为头指针,temp为临时指针,pnew为当前指针
    int i,num;
    head=NULL;//首先将头指针置空
    printf("输入五个学号:");
    for(i=0;i<=4;i++)//输入五个学号
    {
        pnew=(struct student *)malloc(sizeof(struct student));//每次循环都为当前指针分配空间,记录当前数据
        scanf("%d",&num);
        pnew->data=num;
        pnew->next=NULL;//同时将pnew->next置空
        if(head==NULL)//如果头指针为空,把当前指针指向头指针
            head=pnew;
        else//否则把当前指针指向临时指针
            temp->next=pnew;
        temp=pnew;
    }
    while(head!=NULL)
    {
        printf("%d  ",head->data);
        head=head->next;
    }
    printf("\n");
    return 1;  
}
这也是一种链表写法,希望你有用。
2011-11-03 00:05
聪明他小毛
Rank: 1
等 级:新手上路
帖 子:3
专家分:2
注 册:2011-10-27
收藏
得分:0 
回复 4楼 cui_gf
你的temp用得怎么莫名其妙的。
2011-11-03 00:40
快速回复:大哥大姐们,帮帮忙,一个链表问题,输出错误!!!
数据加载中...
 
   



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

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