• C 学生管理系统 显示链表信息、删除链表


    #define _CRT_SECURE_NO_WARNINGS
    #include
    #include
    #include

    //学生节点。
    typedef struct _STU
    {
        char arrStuNum[10];
        char arrStuName[10];
        int iStuScore;
        struct _STU* pNext;//指向下一个节点。
    }STUNODE;
    //申明链表的头和尾。
    STUNODE* g_pHead = NULL;
    STUNODE* g_pEnd = NULL;

    //清空链表。
    void FreeLinkData();

    //打印数据(链表)。
    void ShowStuData();

    //显示指令。
    void ShowOrder();

    int main()
    {
        int nOrder = -1;

        char arrStuNum[10] = { '\0' };
        char arrStuName[10] = { '\0' };
        int iStuScore = -1;
        int  nFlag = 1;

        //显示指令。
        ShowOrder();


        while (nFlag)
        {
            printf("请输入操作指令(0为查看指令)\n");
            scanf("%d", &nOrder);
            switch (nOrder)
            {
            case 1://添加一个学生信息。
                printf("输入学号:");
                scanf("%s", arrStuNum);
                printf("输入姓名:");
                scanf("%s", arrStuName);
                printf("输入分数:");
                scanf("%d", &iStuScore);//取地址。
                AddStuMSG(arrStuNum, arrStuName, iStuScore);
                break;
            case 2:
                break;
            case 3:
                break;
            case 4:
                break;
            case 5:
                break;
            case 6:
                break;
            case 7:
                break;
            case 8://打印数据(链表)。
                ShowStuData();
                break;
            case 9:
                nFlag = 0;
                break;
            case 0:
                //查看指令。
                ShowOrder();
                break;
            default:
                printf("输入的指令不对");
                break;
            }
        }
        //释放链表。
        FreeLinkData();
        system("pause");
        return 0;
    }

    //清空链表。
    void FreeLinkData()
    {   //记录节点。
        STUNODE* pTemp = g_pHead;
        while (g_pHead != NULL)
        {//记录节点。
            pTemp = g_pHead;
            //向后移动一个。
            g_pHead = g_pHead->pNext;
            //删除节点。
            free(pTemp);

        }
    }
    //打印数据。
    void ShowStuData()
    {
        STUNODE* pTemp = g_pHead;
        while (pTemp != NULL)
        {
            printf("学号:%s,姓名:%s,成绩:%d\n", pTemp->arrStuNum, pTemp->arrStuName, pTemp->iStuScore);
            //向下走一步。
            pTemp = pTemp->pNext;

        }
    }

    //显示指令。
    void ShowOrder()
    {
        printf("*******************学生管理系统******************\n");
        printf("******************系统操作指令如下****************\n");
        printf("***1、增加一个学生信息***\n");
        printf("***2、查找指定学生信息(姓名/学号)***\n");
        printf("***3、修改指定学生的信息***\n");
        printf("***4、保存业主的信息到文件***\n");
        printf("***5、读取文件中的业主信息***\n");
        printf("***6、删除指定学生的信息***\n");
        printf("***7、恢复删除的学生信息***\n");
        printf("***8、显示所有学生信息***\n");
        printf("***9、退出系统***\n");
        printf("*****************************************************\n");

    }

  • 相关阅读:
    如何提升新闻公关发稿的效果?
    商品分类代码
    Mysql -常见函数
    互联网Java工程师面试题·Redis 篇·第二弹
    C++ 并发编程实战 第四章 并发操作的同步
    【电商】电商后台设计—商品模块
    文举论金:非农到来!黄金原油全面走势分析策略独家指导
    若依分页问题
    一次node文件操作过多排查过程总结
    算法|Day49 动态规划17
  • 原文地址:https://blog.csdn.net/qq_52119661/article/details/126103942