江南多好臣 2022-12-31 22:47 采纳率: 100%
浏览 178
已结题

创建一个 单向链表 来记录学生信息,人数3--5人;链表结点为结构变量。

题目要求
程序设计要求:

struct stu_info

{

     char stu_num[10];  //学号

     char stu_name[8];  //姓名

     char stu_sex[2];    //性别

     int stu_score    //成绩

     struct stu_info *next;

};
(1)插入新的学生信息(插入节点的位置可任意指定)

(2)删除指定的学生信息

(3)根据学号查询并显示查询到的学生信息

(4)以上三项任务分别自定义函数实现,执行后显示执行结果

(5)程序运行后要求可以循环执行前三项操作,直到选择退出时结束程序

  • 写回答

4条回答 默认 最新

  • 滴水不穿石 2023-01-01 00:44
    关注

    供参考!谢谢!希望对你有帮助。

    img

    img

    img

    img

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    
    typedef struct stu_info
    {
        char stu_num[10]; //学号
        char stu_name[8]; //姓名
        char stu_sex[2];  //性别
        int stu_score;      //成绩
        struct stu_info *next;
    } stu;
    
    void menu(void)
    {
        puts("");
        printf("====================================\n");
        printf("      1->插入新的学生信息\n");
        printf("      2->删除指定学生信息\n");
        printf("      3->根据学号查询学生信息\n");
        printf("      0->退出\n");
        printf("====================================\n");
        puts("请选择对应序号实现相关功能:");
    }
    
    //插入学生信息 head为头结点
    void insert(stu *head)
    {
        /*
        注意:
        要插入的位置从1算起
        若链表为空直接作为第一个结点
        若链表长度小于要插入的位置则直接插到末尾
        其它情况正常插入对应的位置    
        */
        size_t index;
        stu *p = head->next, *pre = head;
    
        stu *node = malloc(sizeof(stu));
        if (!node)
            return;
    
        puts("输入插入位置:");
        scanf("%zd", &index);
    
        puts("\n依次输入学号、姓名、性别、成绩\n彼此用空格隔开:");
        scanf("%9s%7s%1s%d", node->stu_num, node->stu_name, node->stu_sex, &node->stu_score);
    
        while (p && index--)
        {
            p = p->next;
            pre = pre->next;
        }
    
        if (!p)
        {
            pre->next = node;
            node->next = NULL;
        }
        else
        {
            node->next = p->next;
            p->next = node;
        }
    }
    
    //删除指定学生信息
    void delNode(stu *head)
    {
        char s[13];
        puts("请输入待删除学生的姓名:");
        scanf("%12s", s);
    
        stu *p = head->next, *pre = head;
    
        while (p)
        {
            if (strcmp(p->stu_name, s) == 0)
            {
                pre->next = p->next;
                free(p);
                puts("\n删除成功!");
                return;
            }
            pre = pre->next;
            p = p->next;
        }
    
        puts("\n链表是空的/删除失败/查无此人");
    }
    
    //根据学号查并显示学生信息
    void findNode(stu *head)
    {
        char s[10];
        puts("请输入学号:");
        scanf("%9s", s);
    
        stu *p = head->next;
    
        while (p)
        {
            if (strcmp(p->stu_num, s) == 0)
            {
                printf("%s  %s  %s  %d\n", p->stu_num, p->stu_name, p->stu_sex, p->stu_score);
    
                return;
            }
            p = p->next;
        }
    
        puts("\n链表是空的/查无此人");
    }
    
    int main(void)
    {
        //创建头结点
        stu *head = (stu *)malloc(sizeof(stu));
        head->next = NULL;
    
        int i;
    
        while (1)
        {
            menu();
    
            scanf("%d", &i);
            switch (i)
            {
            case 1:
                insert(head);
                break;
            case 2:
                delNode(head);
                break;
            case 3:
                findNode(head);
                break;
            case 0:
                exit(0);
            default:
                break;
            }
    
            getchar();
            getchar();
            system("cls");
        }
    
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 1月9日
  • 已采纳回答 1月1日
  • 创建了问题 12月31日

悬赏问题

  • ¥15 根据以下文字信息,做EA模型图
  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥60 关机时蓝屏并显示KMODE_EXCEPTION_NOT_HANDLED,怎么修?
  • ¥66 如何制作支付宝扫码跳转到发红包界面