• 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 InSertNod(STUNODE* pTemp, char* arrStuNum[10], char arrStuName[10], int iStuScore);

    int main()
    {
        int nOrder = -1;

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

        STUNODE* pTemp = NULL;


        //显示指令。
        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 10://头添加。
                printf("输入学号:");
                scanf("%s", arrStuNum);
                printf("输入姓名:");
                scanf("%s", arrStuName);
                printf("输入分数:");
                scanf("%d", &iStuScore);//取地址。
                AddStuMSGToLinkHead(arrStuNum, arrStuName, iStuScore);
                break;
            case 11://指定位置添加。

                printf("输入需要查找的学号:");
                scanf("%s", arrStuNum);
                pTemp = FindStuByNum(arrStuNum);
                if (NULL != pTemp);
                {
                    //插入。
                    printf("输入学号:");
                    scanf("%s", arrStuNum);
                    printf("输入姓名:");
                    scanf("%s", arrStuName);
                    printf("输入分数:");
                    scanf("%d", &iStuScore);
                    InSertNod(pTemp, arrStuNum, arrStuName, iStuScore);

                }
                break;
            case 2:
                printf("请输入学生学号/姓名");

                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 InSertNod(STUNODE* pTemp, char* arrStuNum[10], char arrStuName[10], int iStuScore)
    {
        //创建节点。
        STUNODE* pNewTemp = malloc(sizeof(STUNODE));
        //成员赋值。
        strcpy(pNewTemp->arrStuNum, arrStuNum);//因为数组做参数传入时则完全是一个指针。
        strcpy(pNewTemp->arrStuName, arrStuName);//因为数组做参数传入时则完全是一个指针。
        pNewTemp->iStuScore = iStuScore;
        pNewTemp->pNext = NULL;

        if (pTemp == g_pEnd)//是尾节点。
        {
            g_pEnd->pNext = pNewTemp;//尾结点下一个指向pNewTmep。
            g_pEnd = pNewTemp;//尾结点变成pNewTmep。
        }
        else//中间节点。
        {
            pNewTemp->pNext = pTemp->pNext;
            pTemp->pNext = pNewTemp;

        }
    }
     

  • 相关阅读:
    Lambda架构与Kappa架构的特性对比
    SSGSSRCSR区别
    小白学python系列————【Day48】设计模式之单例以及pickle模块
    Kafka的消费流程
    java计算机毕业设计铝塑门窗的研制和生产管理源码+系统+mysql数据库+lw文档
    Java 键盘输入n个数进行排序输出
    部署Weblogic10.3.6
    什么是好的视频处理解决方案?
    Elasticsearch7 单节点与集群部署
    【C语言】编程题专项练习+答案
  • 原文地址:https://blog.csdn.net/qq_52119661/article/details/126123752