• 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;

    //查找指定位置学生信息。
    STUNODE* FindStuByNum(char* arrStuNum);

    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 10://头添加。
                printf("输入学号:");
                scanf("%s", arrStuNum);
                printf("输入姓名:");
                scanf("%s", arrStuName);
                printf("输入分数:");
                scanf("%d", &iStuScore);//取地址。
                AddStuMSGToLinkHead(arrStuNum, arrStuName, iStuScore);
                break;
            case 11://指定位置添加。
                printf("输入需要查找的学号:");
                scanf("%s", arrStuNum);
                if (NULL != FindStuByNum(arrStuNum));
                {
                    //插入。
                }
                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;
    }

    STUNODE* FindStuByNum(char* arrStuNum)
    {
        STUNODE* pTemp = g_pHead;
        //检测参数的合法性。
        if (NULL == arrStuNum)
        {
            printf("学号输入错误!\n");
            return NULL;
        }
        //判断链表是否为空。
        if (NULL == g_pHead || NULL == g_pEnd)
        {
            printf("链表为NULL!\n");
            return NULL;
        }
        //遍历链表。
        while (pTemp != NULL)
        {
            if (0 == strcmp(pTemp->arrStuNum, arrStuNum))
            {
                return pTemp;
            }
            pTemp = pTemp->pNext;
        }
        printf("查无此节点!\n");
        return NULL;
    }
     

  • 相关阅读:
    java计算机毕业设计线上远程教学及自主学平台的设计与实现源程序+mysql+系统+lw文档+远程调试
    linux 指定时间 执行一次 命令
    MAUI 框架开发 将 MAUI 嵌入到 WPF 控件里
    Day9 ---- 用户注册与登录
    智能合约安全漏洞与解决方案
    @敏捷组织从业者,开放敏捷架构O-AA™标准考试及认证项目重磅上线!
    2023软件测试面试题汇总
    点云从入门到精通技术详解100篇-基于3D点云的曲面文字检测
    通用密钥,无需密码,在无密码元年实现Passkeys通用密钥登录(基于Django4.2/Python3.10)
    ESP8266-Arduino编程实例-TEMT6000环境光传感器驱动
  • 原文地址:https://blog.csdn.net/qq_52119661/article/details/126116993