• 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 SaveStuToFile();

        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("输入学号:");
                    scanf("%s", arrStuNum);
                    //查找。
                    pTemp = FindStuByNum(arrStuNum);
                    //打印。
                    if (NULL != pTemp);
                    {
                        printf("学号:%s,姓名:%s,成绩:%d\n", pTemp->arrStuNum, pTemp->arrStuName, pTemp->iStuScore);

                    }
                    break;
                case 3:
                    printf("输入需要修改的学号:");
                    scanf("%s", arrStuNum);
                    //查找。
                    pTemp = FindStuByNum(arrStuNum);
                    //打印。
                    if (NULL != pTemp);
                    {
                        //修改学号。
                        printf("输入修改后的学号:");
                        scanf("%s", arrStuNum);
                        strcpy(pTemp->arrStuNum, arrStuNum);
                        //修改姓名
                        printf("输入修改后姓名:");
                        scanf("%s", arrStuName);
                        strcpy(pTemp->arrStuName, arrStuName);
                        //修改分数。
                        printf("输入修改后分数:");
                        scanf("%d", &iStuScore);
                    }

                    break;
                case 4:
                    SaveStuToFile();
                    //保存学生信息。
                    break;
                case 5:
                    break;
                case 6://删除指定学生节点。
                    printf("输入需要删除的学号:");
                    scanf("%s", arrStuNum);
                    //查找。
                    pTemp = FindStuByNum(arrStuNum);
                    //打印。
                    if (NULL != pTemp)
                    {
                        //调用删除学生的函数。

                        DeleteStuNode(pTemp);


                    }
                    break;
                case 7:
                    break;
                case 8://打印数据(链表)。
                    ShowStuData();
                    break;
                case 9:
                    nFlag = 0;
                    break;
                case 0:
                    //查看指令。
                    ShowOrder();
                    break;
                default:
                    printf("输入的指令不对");
                    break;
                }
            }
            //保存。
            SaveStuToFile();
            //释放链表。
            FreeLinkData();
            system("pause");
            return 0;
        }
      

        //保存信息进入文件。
        void SaveStuToFile()
        {//判断链表是否为空。
            FILE* pFile = NULL;
            STUNODE* pTemp = g_pHead;
            char strBuf[30] = { 0 };
            char strScore[10] = { 0 };
            if (NULL == g_pHead)
            {
                printf("链表为空,没有学生信息\n");
                return;
            }
            //打开文件。
            pFile = fopen("dad.txt", "wb+");
            if (NULL == pFile)
            {
                printf("没有学生\n");
                return;
            }
            //操作文件指针。
            while (pTemp)
            {//学号复制进去。
                strcpy(strBuf, pTemp->arrStuNum);
                strcat(strBuf, ",");
                //姓名复制进去。
                strcat(strBuf, pTemp->arrStuName);
                strcat(strBuf, ",");
                //分数复制。
                itoa(pTemp->iStuScore, strScore, 10);//先将整型转换为字符串。
                strcat(strBuf, strScore);

                fwrite(strBuf, 1, strlen(strBuf), pFile);//每次写入1*strLen(strBuf)个字节。
                fwrite("\r\n", 1, strlen("\r\n"), pFile);

                pTemp = pTemp->pNext;
            }
            //关闭文件。
            fclose(pFile);

        }

  • 相关阅读:
    【MATLAB】史上最全的11种数字信号滤波去噪算法全家桶
    惯性测量单元预积分原理与实现
    安卓常见设计模式6------代理模式(Kotlin版)
    trick3-关于目标检测算法好坏的一些衡量指标
    【Spring+SpringMVC+Mybatis】SSM框架的整合、思想、工作原理和优缺点的略微讲解
    Prompt万能框架与常用评估指标
    MySql的基础讲解
    【LLM模型篇】LLaMA2 | Vicuna | EcomGPT等
    Hive性能调优实战
    革命性创新,动画杀手锏 @scroll-timeline
  • 原文地址:https://blog.csdn.net/qq_52119661/article/details/126154613