C语言 做一个学生信息管理系统

cpp 复制代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct person 
{
	char name[30];
	char sex[10];
	int num;
    struct person *next;
}stu;
stu *head = NULL;
void printf_link(stu *head)
{
    stu *pd = head;
    while(pd != NULL)
    {
        printf("姓名:%s\t性别:%s\t学号%d\n",pd->name,pd->sex,pd->num);
        pd = pd->next;
    }
    printf("\n");
}
stu *add(stu *head,stu *stu1)
{
    if(stu1 == NULL )
    {
        return head;
    }
    if(head == NULL)
    {
        head = stu1;
        printf("添加成功\n");
        return head;
    }
    stu *lastNode = head;
    while(lastNode != NULL)
    {
        if(lastNode->next == NULL)
        {
            break;
        }
        else
        {
            lastNode = lastNode->next;
        }
    }
    lastNode->next = stu1;
    printf("添加成功\n");
    return head;
}
stu * add_stu(stu *head)
{
    stu *stu1 = calloc(1,sizeof(stu));
    printf("请输入学员姓名:\n");
    scanf("%s",stu1->name);
    printf("请输入学院性别:\n");
    scanf("%s",stu1->sex);
    printf("请输入学院学号:\n");
    scanf("%d",&stu1->num);  
    head = add(head,stu1); 
    return head;
}
int get_len(stu *head)
{
    int i = 0;
    stu *pd = head;
    while(pd != NULL)
    {
        i++;
        pd = pd->next;
      
    }
    return i;
}
stu *insert(stu *head)
{
    stu *stu1 = calloc(1,sizeof(stu));
    printf("请输入要插入学员的姓名\n");
    scanf("%s",stu1->name);
    printf("请输入要插入学员的性别\n");
    scanf("%s",stu1->sex);
    printf("请输入要插入学员的学号\n");
    scanf("%s",&stu1->num);
    printf("请输入要插入学员的位置(从0开始)\n");
    int index = 0;
    scanf("%d",&index);
    int len = get_len(head);
    if(index > len)
    {
        head = add(head,len);
        return head;
    }
    if(index < 0)
    {
        printf("输入位置有误\n");
        return head;
    }
    if(index == 0)
    {
        stu1->next = head;
        head = stu1;
        printf("添加成功\n");
        return head;
    }
    stu *pd = head;
    for(int i;i < index-1;i++)
    {
        pd = pd->next;
    }
    stu1->next = pd->next;
    pd->next = stu1;
    printf("添加成功\n");
    return head;
}
stu * delete(stu *head)
{
    int a;
    stu *pd=NULL,*p;
    printf("请输入要删除的学号:\n");
    scanf("%d",&a);
    if(!head) 
    {
        printf("系统中已经没有数据可以删除\n");
        return head;
    }
    p=head;
    while(p&&p->num !=a)
    {
        pd=p;
        p=p->next;
    }
    if(p)
    {
        if(!pd) 
        {
        head =head->next;
        }
        else 
        pd->next=p->next;
        free(p);
    }
    return head;
}
void find(stu *head)
{
    int b = 0;
    stu *pd = NULL,*p;
    printf("请输入要查找的学号:\n");
    scanf("%d",&b);
    if(!head) 
    {
        printf("系统中已经没有数据可以删除\n");
        return head;
    }
    p=head;
    while(p&&p->num !=b)
    {
        pd=p;
        p=p->next;
    }
    if(p)
    {
        if(!pd) 
        {
        head =head->next;
        }
        else 
        pd->next=p->next;
        free(p);
    }
    return head;
}
void my_menu(int tag)
{
    switch(tag)
    {
    case 1:
        printf_link(head);
        break;
    case 2:
        head = add_stu(head);
        break;
    case 3:
        head = insert(head);
        break;
    case 4:
        head = delete(head);
        break;
    case 5:
        break;
    case 6:
        break;
    default:
    printf("输入有误请重新输入:\n");
        break;
    }
}
void free_link(stu *head)
{
    stu *pd = head;
    while(pd != NULL)
    {
        stu *next = pd->next;
        free(pd);
        pd = next;
    }
}
int main(int argc, char const *argv[])
{
    while (1)
    {
        printf("1,查询所有学员信息\n2,添加学员信息\n3,插入学员信息\n4,删除学员信息\n5,修改学员信息\n6,查找指定位置的学员\n7,退出程序\n");
        printf("请输入菜单号:\n");
        int tag = 0;
        scanf("%d",&tag);
        if(tag != 7)
        {
            my_menu(tag);
        }
        else{
            free_link(head);
            printf("您下次再来\n");
            break;
        }
    }
    return 0;
}
相关推荐
qy发大财2 分钟前
跳跃游戏(力扣55)
算法·leetcode
BingLin-Liu5 分钟前
蓝桥杯备考:搜索算法之排列问题
算法·职场和发展·蓝桥杯
计算机小白一个8 分钟前
蓝桥杯 Java B 组之岛屿数量、二叉树路径和(区分DFS与回溯)
java·数据结构·算法·蓝桥杯
孤雪心殇9 分钟前
简单易懂,解析Go语言中的Map
开发语言·数据结构·后端·golang·go
庸俗今天不摸鱼21 分钟前
Canvas进阶-4、边界检测(流光,鼠标拖尾)
开发语言·前端·javascript·计算机外设
菠菠萝宝22 分钟前
【Java八股文】10-数据结构与算法面试篇
java·开发语言·面试·红黑树·跳表·排序·lru
奔跑吧邓邓子24 分钟前
【Python爬虫(36)】深挖多进程爬虫性能优化:从通信到负载均衡
开发语言·爬虫·python·性能优化·负载均衡·多进程
不会Hello World的小苗28 分钟前
Java——链表(LinkedList)
java·开发语言·链表
lsx20240641 分钟前
Perl 面向对象编程指南
开发语言
curemoon1 小时前
理解都远正态分布中指数项的精度矩阵(协方差逆矩阵)
人工智能·算法·矩阵