| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1397 人关注过本帖
标题:简单的链表问题,有一点小问题,求大佬看看怎么解决
只看楼主 加入收藏
归园田居
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2019-12-26
结帖率:100%
收藏
 问题点数:0 回复次数:1 
简单的链表问题,有一点小问题,求大佬看看怎么解决
问题;
图片附件: 游客没有浏览图片的权限,请 登录注册

我的代码(用的软件是codeblocks):
#include<stdio.h>
#include<stdlib.h>
#include <string.h>
#include <malloc.h>
//定义结构体
struct Student
{
    char num[20];
    char name[20];
    int age;
    struct Student *next;
};
//函数声明
void setup(struct Student **head);
void output(struct Student *head);
void dele(struct Student **head);
void insert2(struct Student **head);
void insert3(struct Student **head);
//主函数
int main()
{
    struct Student *head=NULL;
    int x;
    printf("输入1:建立学生信息表;\n输入2:在指定学生之前插入新的学生信息;\n输入3:在学生表尾部插入新的学生信息;\n输入4:输出所有学生信息;\n输入5:删除指定的学生信息;\n");
    do
    {
        printf("\n请输入你需要使用的功能:");
        scanf("%d",&x);
        switch(x)
        {
        case 0 :
            break;
        case 1 :
            setup(&head);
            break;
        case 2:
            insert2(&head);
            break;
        case 3:
            insert3(&head);
            break;
        case 4 :
            output(head);
            break;
        case 5 :
            dele(&head);
            break;
        default :
            printf ("选择错误!\n");
            break;
        }
//建立动态链表(指针操作)
void setup(struct Student **head)
{
    struct Student *p = (struct Student*)malloc(sizeof(struct Student));
    struct Student *stu=NULL;
    printf("num:");
    scanf("%s",(p->num));
    printf("name:");
    scanf("%s",(p->name));
    printf("age:");
    scanf("%d",&p->age);
    p->next=NULL;
    if(*head == NULL)
    {
        *head = p;
    }
    else
    {
        stu = *head;
        while(stu->next != NULL)
        {
            stu = stu->next;
        }
        stu->next = p;
    }
}
//在链表开头或者中间插入节点(指针操作)
void insert2(struct Student **head)
{
    struct Student *p1,*p2;
    p1=*head;
    p2=p1->next;
    char arri[20];
    printf("输入要插入的学生位置的学号:");
    scanf("%s",arri);
    struct Student *p=(struct Student*)malloc(sizeof(struct Student));
    printf("输入要插入的学生信息:\n");
    printf("num:");
    scanf("%s",(p->num));
    printf("name:");
    scanf("%s",(p->name));
    printf("age:");
    scanf("%d",&p->age);
    p->next=NULL;
    while(p2!=NULL)
    {
        if(strcmp(arri,p2->num)==0)
        {
            p1->next=p;
            p->next=p2;
        }
        p1=p2;
        p2=p2->next;
    }
    output(*head);
}
//在链表尾插入节点(指针操作)
void insert3(struct Student **head)
{
    struct Student *p = (struct Student*)malloc(sizeof(struct Student));
    printf("输入要插入的学生信息:\n");
    printf("num:");
    scanf("%s",(p->num));
    printf("name:");
    scanf("%s",(p->name));
    printf("age:");
    scanf("%d",&p->age);
    p->next=NULL;
    struct Student *p1;
    while(p1->next!=NULL)
    {
        p1=p1->next;
    }
    p1->next=p;
    output(*head);
}
//输出整个链表(把整个表传过来)
void output(struct Student *head)
{
    while(head != NULL)
    {
        printf("学号:%s;姓名:%s;年龄:%d\n",head->num,head->name,head->age);
        head=head->next;
    }
}
//删除指定的节点
void dele(struct Student **head)
{
    char arr1[20];
    struct Student *p1 = NULL;
    struct Student *p2 = *head;
    printf("请输入要删除的学生的学号:\n");
    scanf("%s",arr1);
    while(p2!=NULL)
    {
        if(p1==NULL&&strcmp(arr1,p2->num)==0)
        {
            *head = p2->next;
            free(p2);
            break ;
        }
        else if(strcmp(arr1,p2->num)==0)
        {
            p1->next = p2->next;
            free(p2);
            break ;
        }
        p1=p2;
        p2=p2->next;
    }
    output(*head);
}

其中建立、输出和删除可以正常进行:
图片附件: 游客没有浏览图片的权限,请 登录注册

错误:
这里的功能2(在开头位置或中间插入)无法插入;
功能3(在表尾插入)会直接结束。
图片附件: 游客没有浏览图片的权限,请 登录注册

这两个插入怎么解决呢?
(这个网站没用过,我怕传输有问题,下面是完整的)
第十、十一周实验课练习内容(结构体和链表).zip (392.48 KB)
搜索更多相关主题的帖子: printf head next Student struct 
2019-12-26 12:03
lwei
Rank: 5Rank: 5
等 级:职业侠客
威 望:3
帖 子:197
专家分:369
注 册:2005-5-4
收藏
得分:0 
void insert3(struct Student **head)
{
    struct Student *p = (struct Student*)malloc(sizeof(struct Student));
    printf("输入要插入的学生信息:\n");
    printf("num:");
    scanf("%s",(p->num));
    printf("name:");
    scanf("%s",(p->name));
    printf("age:");
    scanf("%d",&p->age);
    p->next=NULL;                  //p 就没有插入到链表中去,能成功才奇怪了。 对了,这个函数退出之后,前面分配的内存也完蛋了,关机重启吧
    struct Student *p1;              
    while(p1->next!=NULL)    //p1 就是一个空指针,对空操作不中断你中断谁
    {
        p1=p1->next;
    }
    p1->next=p;
    output(*head);
}

那个insert2 同样的问题,增加了节点,只有一种情况挂上链表。

2019-12-26 23:17
快速回复:简单的链表问题,有一点小问题,求大佬看看怎么解决
数据加载中...
 
   



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

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