| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 554 人关注过本帖
标题:求改错,一个链表的代码,谢谢
只看楼主 加入收藏
ppdva
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2010-11-28
收藏
 问题点数:0 回复次数:3 
求改错,一个链表的代码,谢谢
#include<iostream.h>
#include<string.h>
struct STUDENT
{
    char num[10];
    int score;
    STUDENT *next;
}

STUDENT *Create()    //新建链表
{
    STUDENT *p,*q,*head;
    int i=1,number;
    cout<<"请输入学生人数:"<<endl;
    cin>>number;
    cout<<"请按学号顺序输入各位同学的学号和成绩!"<<endl;
    head=0;
    while(i<=number)
    {
        p=new STUDENT;
        cout<<"请输入第"<<i<<"位同学的学号和成绩:";
        cin>>p->num;
        cin>>p->score;
        if(head==0)
        {
            head=p;
            q=p;
        }
    else
    {
        q->next=p;q=p;
    }
    i++;
    }
    q->next=0;
    return(head);
}

void Travel(STUDENT *head)    //遍历链表
{
STUDENT *p;
int i=1;
p=head;
cout<<"链表中的数据输出如下:"<<endl;
while(p!=0)
{
    cout<<"第"<<i<<"个节点中的数据为"<<endl;
    cout<<p->num<<" "<<p-score<<endl;
    p=p->next;
    i++;
}
}

STUDENT *Insertnode(STUDENT *head,STUDENT *p)    //在链表中插入一个节点
{
 STUDENT *be,*ne;
 if(head==0)
 {
     head=p;
     p->next=0;
     return(head);
 }
 if(strcmp(head->num,p->num)>=0)
 {
     p->next=head;
     head=p;
     return(head);
 }
 be=ne=head;
 while(ne!=0 && strcmp(ne->num,p->num)<0)
 {
     be=ne;
     ne=ne->next;
 }
 p->next=ne;
 be->next=p;
 return(head);
}

STUDENT *Deletenode(STUDENT *head,char num[])    //在链表中删除一个节点
{
    STUDENT *be,*p;
    if(head==NULL)
    {
        cout<<"链表已经为空,无节点可以删除!"<<endl;
        return(head);
    }
    if(strcmp(head->num,num)==0)
    {
        p=head;
        head=head->next;
        delete p;
    }
    else
    {
        be=p=head;
        while(strcmp(p->num,num)!=0 && p->next!=NULL)
        {
            be=p;
            p=p->next;
        }
        if(strcmp(p->num,num)==0)
        {
            be->next=p->next;
            delete p;
            cout<<"删除了一个节点!"<<endl;
        }
        else
            cout<<"链表中没有找到所要删除的节点!"<<endl;
    }
    return(head);
}

void releaschain(STUDENT *head)         //释放链表
{
    STUDENT *p;
    while(head)
    {
        p=head;
        head=head->next;
        delete p;
    }
}

void main(void)
{
    STUDENT *head,*t;
    char n[10];
    head=Create();
    Travel(head);
    t=new STUDENT;
    cout<<"请输入需要插入同学的学号和成绩:";
    cin>>t->num>>t->score;
    head=Insertnode(head,t);
    Travel(head);
    cout<<"请输入要删除同学的学号:";
    cin>>n;
    head=Deletenode(head,n);
    Travel(head);
    releasechain(head);
}
搜索更多相关主题的帖子: 链表 改错 代码 
2010-12-02 12:57
ppdva
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2010-11-28
收藏
得分:0 
改过了,struct要有个分号,struct{……};
最后的main函数的release拼写错误,错误提示为函数没有定义。改过后就可以了
2010-12-02 13:06
cadypeng
Rank: 1
等 级:新手上路
帖 子:5
专家分:7
注 册:2010-12-4
收藏
得分:0 
回复 楼主 ppdva
这个问题也要拿到这来问吗 兄弟。。。
遍历节点时候 输出成绩那里还少了个尖括号p->score

如果改变了事情就尝试改变自己。
2010-12-04 23:36
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
struct STUDENT
{
    char num[10];
    int score;
    STUDENT *next;
};
落下分号了
输出成绩那里还少了个尖括号p->score

                                         
===========深入<----------------->浅出============
2010-12-05 10:31
快速回复:求改错,一个链表的代码,谢谢
数据加载中...
 
   



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

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