【顺序表&学生信息管理系统】学完顺序表就可以上高速写学生信息管理系统(上)

简介: 【顺序表&学生信息管理系统】学完顺序表就可以上高速写学生信息管理系统

另外之前我也以为这个很难写,写完后的才知道这其实就是顺序表和排序的结合实现,只是额外增加了一点人机交互的一些输入输出而已,其实它很简单就可以实现.(耗时一下午左右就可完成)


73cc5cf926184e45a7aafc0d7e8ad68c.png

0.首先我们需要定义顺序表

typedef struct Student
{
  char id[18];
  char name[18];
  int grade;
}Student;//学生结构体类型重命名
typedef struct SeqList
{
  Student* student;//动态数组,方便后续扩容
  int size;
  int capacity;
}SeqList;//顺序表结构体类型重命名

7925cab2a8464a9ca8996d4a7819cecd.png


你可以看成是顺序表这个盒子里面装着学生这个盒子的嵌套,盒子里面装着数组长度,学号之类的信息


1.我们再在主函数里定义一个顺序表结构体变量,并调用初始化顺序表初始化接口 函数


    SeqList ST;
  SeqListInit(&ST);//调用顺序表初始化接口函数
void SeqListInit(SeqList* ps)
{
  ps->student = (Student*)malloc(sizeof(Student)*4);//注意这里的是学生结构体类型,可以联想为int类型
  if (ps->student == NULL)
  {
    printf("malloc fail\n");
    exit(-1);
  }
  ps->size = 0;
  ps->capacity = 4;//先给它分配4个Student结构体类型内存大小空间容量
}

2.为了更好的实现人机交互,这里我们用到打印菜单来方便用户选择

void meau()
{
  printf("************************\n");
  printf("*****  0.退出程序  *****\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");
}

打印出来就是这样的啦,不是很酷!

00adcda1d3694beeb1b229e015ad68a5.png

3.主函数内的主要轮廓(有了轮廓之后就可以一步步实现这个代码,不要着急

do//先执行一次
{
  int input = 0;
  printf("请输入你的选择:>");
  scanf("%d", &input);
  switch (input)
  {
  case 0:
    printf("退出程序\n");
    printf("\n");//为了打印界面更美观,所以换行
    break;//勿漏
  case 1:
    printf("录入学生信息\n");
    printf("\n");
    break;
    case 2:
        printf("打印学生信息\n");
      SeqListPrint(&ST);//调用打印函数接口
      printf("\n");
    break;
  case 3:
    printf("插入学生信息\n");
    printf("\n");
    break;
  case 4:
    printf("统计学生个数\n");
    printf("\n");
    break;
  case 5:
    printf("按姓名来排序\n");
    printf("\n");
    break;
  case 6:
    printf("按学号来排序\n");
    printf("\n");
    break;
  case 7:
    printf("查找学生信息\n");
    printf("\n");
    break;
  case 8:
    printf("删除学生信息\n");
    printf("\n");
    break;
    default :
        printf("输入有误,请重新输入\n");
    printf("\n");
    break;
  }
} while (input);//当输入0时为假后退出

4.接下来我们就分模块化拆解代码,建议写一模块代码就测试一下,便于找BUG  

4-0退出程序代码

    case 0:
      printf("退出程序\n");
      printf("\n");
      break;

4-1录入学生信息代码

    //主函数代码:
          case 1:
      printf("录入学生信息\n");
      int n = 0;
      printf("请输入待插入学生的个数;>");
      scanf("%d", &n);
      for (int i = 0; i < n; i++)
      {
        Student stu;
        printf("请输入待插入学生的学号,姓名,分数:>");
        scanf("%s%s%d", stu.id, stu.name, &stu.grade);//字符数组输入时不需要&
        SeqListPushBack(&ST, stu);//调用尾插建立顺序表的接口函数
      }
      printf("插入成功\n");
      printf("\n");
      break;

尾插建立顺序表的接口函数(和顺序表那里讲的一模一样)

void CheckCapacity(SeqList* ps)//检查是否需要扩容函数
{
  if (ps->size == ps->capacity)
  {
    int newcapacity = 2 * ps->capacity;
    Student* temp = realloc(ps->student, sizeof(Student) * newcapacity);
    assert(!temp);
    ps->student = temp;
    ps->capacity = newcapacity;
  }
}
void SeqListPushBack(SeqList* ps, Student stu)//尾插建立顺序表
{
  CheckCapacity(ps);//调用检查是否需要扩容函数接口
  ps->student[ps->size] = stu;
  ps->size++;//勿漏
}

4-2打印学生信息代码

    case 2:
      printf("打印学生信息\n");
      SeqListPrint(&ST);//调用打印函数接口
      printf("\n");
      break;

对应函数接口:

void SeqListPrint(SeqList* ps)
{
  for (int i = 0; i < ps->size; i++)
  {
    printf("学号:%s\t名字:%s\t分数:%d\n", ps->student[i].id, ps->student[i].name, ps->student[i].grade);
  }
}

4-3指定位置插入学生信息代码:(题目要求使用指定的任意位置插入)

    case 3:
      printf("插入学生信息\n");
      //插入学生的位置
      int pos = 0;
      printf("请输入你要待插入学生信息的位置(目前可插入位置必须小于等于%d):>", ST.size);
      scanf("%d", &pos);
      //待插入学生的信息
      Student stu;
      printf("请输入待插入学生的学号,姓名,分数:>");
      scanf("%s%s%d", stu.id, stu.name, &stu.grade);//装配好学生结构体类型,后续传参
      SeqListInsert(&ST, stu, pos - 1);//调用顺序表任意位置插入函数接口
      printf("插入成功\n");
      printf("\n");
      break;

函数接口:

void SeqListInsert(SeqList* ps, Student stu, int pos)//注意传入参数的类型
{
  CheckCapacity(ps);//调用检查是否需要扩容的函数接口
  int end = ps->size - 1;
  while (end >= pos)
  {
    ps->student[end + 1] = ps->student[end];//注意从后面那端开始后移
    end--;
  }
  ps->student[pos] = stu;
  ps->size++;//勿漏
}
//总结:往哪一端移动就从哪一端开始移动

4-4统计学生个数

  case 4:
      printf("统计学生个数\n");
      int sz = SeqListSize(&ST);//调用函数接口并返回值用sz接收
      printf("当前统计表中学生的个数为:%d\n", sz);
      printf("\n");
      break;

函数接口:

1. int SeqListSize(SeqList* ps)
2. {
3.  return ps->size;
4. }

4-5按姓名来排序(题目要求使用直接插入排序来实现)

    case 5:
      printf("按姓名来排序\n");
      InsertSort(&ST);//直接插入排序函数接口调用
      SeqListPrint(&ST);//排完序后打印顺序表,调用函数接口
      printf("\n");
      break;

函数接口:

void InsertSort(SeqList* ps)
{
  for (int i = 0; i < ps->size - 1; i++)
  {
    int end = i;
    Student temp = ps->student[i + 1];
    while (end >= 0)
    {
      if ((strcmp(ps->student[end].name,temp.name))>0)//字符数组比较大小使用strcmp函数
      {
        ps->student[end + 1] = ps->student[end];
        end--;
      }
      else
      {
        break;
      }
    }
    ps->student[end + 1] = temp;
  }
}

4-6按学号来排序(题目要求使用快速排序来实现)

    case 6:
      printf("按学号来排序\n");
      QuickSort(&ST, 0, ST.size - 1);//快排函数接口调用
      SeqListPrint(&ST);//顺序表打印函数接口调用
      printf("\n");
      break;
目录
相关文章
|
7月前
|
存储 机器学习/深度学习 API
顺序表:数据结构的建筑积木
朋友们大家好啊,本节内容我们进入数据结构的第二节,顺序表有关内容,同步我们会学习计组原理与cpp相关知识 本节我们重点探讨动态顺序表关于插入数据和删除数据的多种情况的分析
|
2月前
基于顺序表的学生成绩管理系统
基于顺序表的学生成绩管理系统
28 0
|
6月前
|
算法
$停车场管理系统 栈与队列
$停车场管理系统 栈与队列
|
7月前
|
存储
【数据结构】----顺序表项目-通讯录
【数据结构】----顺序表项目-通讯录
28 0
|
7月前
|
存储 机器学习/深度学习 供应链
数据结构课程设计 仓储管理系统
数据结构课程设计 仓储管理系统
54 0
|
7月前
|
存储 算法 Java
【数据结构与算法】4.自主实现单链表的增删查改
【数据结构与算法】4.自主实现单链表的增删查改
|
存储 搜索推荐
【数据结构】第二站:顺序表
【数据结构】第二站:顺序表
42 0
|
存储 算法 Java
图的操作和应用之景区信息管理系统(数据结构课程设计)
0001:图的操作和应用之景区信息管理系统(C++版数据结构课程设计) 现有一个景区,景区里面有若干个景点,景点之间满足以下条件: (1) 某些景点之间铺设了道路(相邻) (2) 这些道路都是可以双向行驶的(无向图) (3) 从任意一个景点出发都可以游览整个景区(连通图) 开发景区信息管理系统,对景区的信息进行管理。使用图的数据结构来保存景区景点信息,为用户提供创建图、查询景点信息、旅游景点导航、搜索最短路径、铺设电路规划等功能。 文章目录0001:图的操作和应用之景区信息管理系统(C++版数据结构课程设
图的操作和应用之景区信息管理系统(数据结构课程设计)
|
存储 计算机视觉
利用单链表实现学生信息管理系统
利用单链表实现学生信息管理系统
170 0
|
存储 算法 C语言
【数据结构】停车场问题
【数据结构】停车场问题
98 0