df3379 发表于 2019-7-24 21:15:18

链表输出及结构体问题

本帖最后由 df3379 于 2019-7-24 21:18 编辑

/*
要求:设计一个程序,
*/

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

struct NODE/*定义结构体类型,
这只是一个类型,不是结构体变量
*/
{
    char name;
        int age;
        char sex;
        char num;
        struct NODE *next;//用于保存下一个结构体变量的地址,指向下一个结构体变量
};

struct NODE *CreateLink(void);//函数声明,创建链表
void Init(struct NODE *);//函数声明,链表结点初始化
void OutputLink(struct NODE *);//函数声明,输出链表
void InsertNode(struct NODE *);//函数声明,插入结点

int main(void)
{
    char ch='\0';//用于判断是否执行相关程序
        struct NODE *head=NULL;//定义指向空的struct NODE型结构体变量的头指针

        //以下创建链表
        printf("是否创建当前链表?(Y/N)");
        while(1)
        {
          scanf("%c",&ch);
                getchar();//吸收回车,
                if(('Y'==ch)||('y'==ch))
                {
                  head=CreateLink();
                        Init(head);
                        OutputLink(head);
                        break;//执行完毕退出创建链表
                }
                else if(('N'==ch)||('n'==ch))
                {
                  return 0;
                }
                else
                {
                  printf("请重新输入(Y/N):");
                }
        }

        //以下插入结点
        printf("是否要插入结点?(Y/N)");
        ch='\0';
        while(1)
        {
          scanf("%c",&ch);
                getchar();
                if(('Y'==ch)||('y'==ch))
                {
                  InsertNode(head);
                        OutputLink(head);
                        break;
                }
                else if(('N'==ch)||('n'==ch))
                {
                  break;
                }
                else
                {
                  printf("请重新输入(Y/N):");
                }
        }
        return 0;
}

//以下为创建链表函数
struct NODE *CreateLink(void)
{
    int i=0;//循环变量
        int cnt=0;//学生的数量
        struct NODE *head=malloc(sizeof*head);//定义头指针,并初始化指向头结点
        struct NODE *move;
        if(NULL==head)
        {
          printf("内存分配失败,程序终止!");
                exit(-1);
        }
        move=head;
        move->next=NULL;
        printf("请输入学生的数量:");
        scanf("%d",&cnt);
        getchar();
        for(i=0;i<cnt;++i)
        {
          struct NODE *fresh=malloc(sizeof*fresh);//
                if(NULL==fresh)
                {
                  printf("内存分配失败,程序终止!");
                        exit(-1);
                }

                //结点连接三部曲
                move->next=fresh;//将新的结点连接到后面
                fresh->next=NULL;//新连上的结点初始化为指向NULL
                move=fresh;//指针变量move向后移动,指向当前新建的结点
        }
        return head;
}

//以下为链表结点初始化
void Init(struct NODE *head)
{
    int i=1;
        struct NODE *move=head->next;//初始化为首结点
        while(NULL!=move)
        {
          printf("请输入第%d个学生的信息\n\n依次输入:姓名 年龄 性别 学号\n\n",i);
                scanf("%s%d%s%s",move->name,&move->age,&move->sex,move->num);
                getchar();
                printf("%s %d %s %s\n",move->name,move->age,move->sex,move->num);
                move=move->next;
                ++i;
                printf("\n");
        }

        return;
}

//以下为链表输出函数
void OutputLink(struct NODE *head)
{
    struct NODE *move=head;
        if(NULL==move)
        {
          printf("未创建链表\n");
                return;
        }
        if(NULL==move->next)
        {
          printf("链表为空\n");
               
        }
        while(NULL!=move->next)
        {
                printf("[姓名:%s 年龄:%d 性别:%s 学号:]->\n\n",move->next->name,move->next->age,move->next->sex);
          move=move->next;//使指针变量指向下一个结点
        }
       
}

//以下为插入结点函数
void InsertNode(struct NODE *head)
{
    char num="\0";//输入一个学号,在这个学号的后面插入一个学生的信息
        struct NODE *fresh=malloc(sizeof*fresh);//存储要插入的学生的信息
        printf("请输入你想在那个学号的学生后面再插入一个学生信息:");
        while(1)//解决输入无该学号学生的BUG
        {
          struct NODE *move=head->next;//
                scanf("%s",&num);
                getchar();
                while(NULL!=move)
                {
                  if(0==strcmp(num,move->num))
                        {
                          printf("请输入插入学生的信息\n\n分别是:姓名、年龄、性别、学号:\n\n");
                                scanf("%s%d%s%s",&fresh->name,&fresh->age,&fresh->sex,&fresh->num);
                                getchar();
                                //插入结点
                                fresh->next=move->next;
                                move->next=fresh;
                                return;
                        }
                        move=move->next;
                }
                printf("无该结点,请重新输入:");
        }
}

http://i2.tiimg.com/693900/4be33132137673ee.jpg

问题如下:
1.第122行学号输出了两次。这是为什么呢?

2.第147行学号的输出代码我都没有填写,居然有学号输出。这又是为啥?

mqcake 发表于 2019-7-25 11:08:01

问题在于你的char sex;为2没有结束符,导致和后面的学号连起来了,改为char sex;即可!

df3379 发表于 2019-7-25 13:42:30

本帖最后由 df3379 于 2019-7-25 13:44 编辑

少了\0的位置。难怪难怪!谢谢了!
页: [1]
查看完整版本: 链表输出及结构体问题