学生成绩管理系统

学生成绩管理系统

学生成绩管理系统

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <stdlib.h>
#include <malloc.h>
#include <string.h>
using namespace std;
int MAXSIZE = 100;
typedef struct{
    char no[8];
    char name[20];
    int price;
}Student;
typedef struct{
    Student *elem;
    int length;
}SqList;

//以下为基本操作
int CreatLink(SqList *L)
{
    L->elem = NULL;
    L->elem = (Student *)malloc(sizeof(Student)*MAXSIZE);
    if (!L->elem)
        exit(-1);
    L->length = 0;

    return 1;
}
int InputSomeone(SqList *L)
{
    cout << "请输入要选择输入几个学生信息:";
    int num;
    cin >> num;
    for (int i = 0; i<num; i++)
    {
        cout << "学号:";
        cin >> L->elem[i].no;
        cout << "姓名:";
        cin >> L->elem[i].name;
        cout << "分数:";
        cin >> L->elem[i].price;
        L->length++;
    }
    return 1;
}
int Insert(SqList *L)
{
    int k, i;
    Student e;
    cout << "请输入要插入的位置:";
    cin >> i;
    cout << "请输入具体信息:" << endl;
    cout << "学号:";
    cin >> e.no;
    cout << "姓名:";
    cin >> e.name;
    cout << "分数:";
    cin >> e.price;
    if (i<1 || i>L->length + 1)
    {
        printf("此处有误1");
        return 0;
    }
    if (L->length == MAXSIZE)
    {
        printf("此处有误2");
        return 0;
    }
    for (k = L->length - 1; k >= i - 1; k--)
    {
        L->elem[k + 1] = L->elem[k];
    }
    strcpy(L->elem[i - 1].no, e.no);
    strcpy(L->elem[i - 1].name, e.name);
    L->elem[i - 1].price = e.price;
    ++L->length;
    return 1;
}
int Delete(SqList *L)
{
    int pos;
    printf("请输入要删除的位置:");
    scanf("%d", &pos);
    if (pos<1 || pos>L->length)
        return 0;
    while (pos<L->length)
    {
        L->elem[pos - 1] = L->elem[pos];
        ++pos;
    }
    L->length--;
    return 1;
}
int SumPoepleNumber(SqList *L)
{
    return L->length;
}
void Output(SqList *L)
{
    for (int i = 0; i < L->length; i++)
    {
        printf("\n学号是:%s", L->elem[i].no);
        printf("\n姓名是:%s", L->elem[i].name);
        printf("\n分数是:%d", L->elem[i].price);
        printf("\n\n");
    }
}

//以下为排序操作
//折半插入排序_根据姓名
void BinaryInsertSort_Name(SqList *L, int n)
{
    int i, j;
    Student stu;
    for (i = 1; i < n; i++)
    {
        stu = L->elem[i];
        for (j = i - 1; strcmp(stu.name, L->elem[j].name) < 0; j--)
            L->elem[j + 1] = L->elem[j];
        L->elem[j + 1] = stu;
    }
}
//折半插入排序_根据分数
void BinaryInsertSort_Core(SqList *L, int n)
{
    int i, j;
    Student stu;
    for (i = 1; i < n; i++)
    {
        stu = L->elem[i];
        for (j = i - 1; stu.price<L->elem[j].price; j--)
            L->elem[j + 1] = L->elem[j];
        L->elem[j + 1] = stu;
    }
}

//以下为查找操作
//折半查找_根据姓名_非递归算法
int BinarySearch_Name(SqList *L,char a[],int n) //a[]代表输入的姓名的形参
{
    int low = 0, high = n - 1;
    int mid;
    while (low <= high)
    {
        mid = (low + high) / 2;
        if (strcmp(a, L->elem[mid].name) == 0)
            return mid;
        else if (strcmp(a, L->elem[mid].name) < 0)
            high = mid - 1;
        else
            low = mid + 1;
    }
    return -1;
}
//折半查找_根据成绩_递归算法
int BinarySearch_Core(SqList *L, int num, int low, int high)
{
    //引入静态变量使得mid
    int i = low;
    int j = high;
    int mid = (low + high) >> 1;
    if (i > j) {
        return -1;
    }
    if (num == L->elem[mid].price) {
        return mid;
    }
    else if (num > L->elem[mid].price) {
        return BinarySearch_Core(L, num, mid + 1, j);
    }
    else {
        return BinarySearch_Core(L, num, i, mid - 1);
    }
    return -1;
}
//菜单显示
void menu()
{
    printf("*******************学生成绩管理系统*********************\n\n");
    printf("主菜单:\n");
    printf("  1.建立顺序表             "); printf("2.输入学生信息\n");
    printf("  3.插入学生信息           "); printf("4.删除学生信息\n");
    printf("  5.统计现在学生人数       "); printf("6.输出所有人的信息\n");
    printf("  7.根据姓名排序           "); printf("8.根据分数排序\n");
    printf("  9.根据学生姓名查找       "); printf("10.根据学生成绩查找\n");
    printf("  0.退出该系统       ");
}
int main()
{
    SqList L;
    char NowName[20];
    char no[8];
    menu();
    int len, sum, pos;
    int choice=-1;
    cout << endl << endl;
    while (choice != 0)
    {
        cout <<"请选择功能:";
        cin >> choice;
        switch (choice)
        {
        case 1:
            CreatLink(&L);
            break;
        case 2:
            InputSomeone(&L);
            break;
        case 3:
            Insert(&L);
            break;
        case 4:
            Delete(&L);
            break;
        case 5:
            sum = SumPoepleNumber(&L);
            cout << "现在的人数是:" << sum << endl;
            break;
        case 6:
            Output(&L);
            break;
        case 7:
            len = SumPoepleNumber(&L);
            BinaryInsertSort_Name(&L, len);
            break;
        case 8:
            len = SumPoepleNumber(&L);
            BinaryInsertSort_Core(&L, len);
            break;
        case 9:
            len = SumPoepleNumber(&L);
            char a[10];
            cin >> a;
            pos = BinarySearch_Name(&L, a, len);
            if (pos != -1)
            {
                cout << endl << "查找的结果是:" << endl << "学号:" << L.elem[pos].no << "   ";
                cout << "姓名:" << L.elem[pos].name << "  ";
                cout << "分数:" << L.elem[pos].price << endl;
            }
            else
                cout << "没有查询到该学生信息" << endl << endl;
            break;
        case 10:
            int core;
            cin >> core;
            len = SumPoepleNumber(&L);
            pos = BinarySearch_Core(&L, core, 0, len);
            if (pos != -1)
            {
                cout << endl << "查找的结果是:" << endl << "学号:" << L.elem[pos].no << "   ";
                cout << "姓名:" << L.elem[pos].name << "  ";
                cout << "分数:" << L.elem[pos].price << endl << endl;
            }
            else
                cout << "没有查询到该学生信息" << endl;
            break;
        case 0:
            printf("**************************谢谢使用本系统*****************************\n");
            break;
        }
    }
    system("pause");
}
12-22 02:29