| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 505 人关注过本帖
标题:初学链表的问题
只看楼主 加入收藏
宇智波曌
Rank: 2
等 级:论坛游民
帖 子:98
专家分:15
注 册:2011-4-17
结帖率:100%
收藏
 问题点数:0 回复次数:0 
初学链表的问题
#include<stdio.h>
#include<stdlib.h>

typedef struct std     //学生的数据结构类型
{    int no;
    char stunum[10];
    char stuname[10];
    char sex[5];

}stu;

typedef struct Node// 单链表的结点类型
{
   
    stu data;
    struct Node *next;
}LNode, *LinkList;
LinkList L;      //定义头指针
stu s1;
char str[81];
void CreateList(LinkList L)
{
    LinkList p,q;
    FILE *fp;
    //int i;
   
    if((fp=fopen("abc.txt","r"))==NULL)
    {
        printf("打开文件失败,请检查路径设置!\n\n");
        exit(1);
    }
    fgets(str,81,fp);
    printf("\t%s\n",str);
    L=(LinkList)malloc(sizeof(LNode));
    if(L==NULL)
    {
        printf("失败 !");
        exit(0);
    }
    L->next=NULL;
    q = L;
    while(!feof(fp))
    {
   
        p=(LinkList)malloc(sizeof(LNode));
        if(p==NULL)
        {
            printf("失败 !");
            exit(0);
        }
        p->next=NULL;
        fscanf(fp,"%d%s%s%s%s%d%d%d",&p->data.no,p->data.stunum,p->data.stuname,p->data.sex);

        q->next = p;
        q = p;   
    }
    fclose(fp);
    printf("\n");
        p=L->next;
    while(p!=NULL)
        {
            printf("\t%d\t%s\t%s\t%s\t%s\t%d\t%d\t%d\n",p->data.no,p->data.stunum,p->data.stuname,p->data.sex);
            p=p->next;

        }
printf("创建成功!\n");   
   


}   




//删除记录
void ListDelete(LinkList L,int i)
{
    int num;
    int j=1;
    LinkList p,q;
    q=(LinkList)malloc(sizeof(LNode));//申请结点空间
    p=L->next;
    printf("请输入要删除的学生的编号:\n");
    scanf("%d",&num);

    while(p!=NULL);
    {
        if(p->data.no==num &&p->next!=NULL)      /*怎么解决p->next为空时候的情况?即删除最后一条记录的时候*/
        {   
          p=p->next;//找结点并删除
        }
          printf("\t%d\t%s\t%s\t%s\t%s\t%d\t%d\t%d\n",p->data.no,p->data.stunum,p->data.stuname,p->data.sex);
        p=p->next;
    }
}

//主函数
void main()
{
    int i;

    while(1)
    {
        printf("******学生成绩管理系统******\n");
        printf("****1.创建链表    ******\n");
        printf("****2.删除记录    ******\n");
        printf("****0.退出系统    ******\n");
        printf("请输入您的选择:\n");
        scanf("%d",&i);
        switch(i)
        {
            case 1:CreateList(L);break;
            case 2:ListDelete(L,5);break;//删除第10记录
            case 0:exit(0);
            default:printf("输入不正确,请重新输入!\n");
        }
    }
}
请问高手,显示 红色 的部分怎么解决!帮帮忙啊!
搜索更多相关主题的帖子: 检查 include 
2011-10-08 12:37
快速回复:初学链表的问题
数据加载中...
 
   



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

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