LINUX下的C学生信息管理系统

第一次写,难免会有些紧张 ,这是我们的课程设计作业,拉出来分享下。

/*
    版本号 V1.0
    时间 2014.6.24*/

#include
#include
#include
#include
#define SI sizeof(stu)
#define PT "^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^ ^…^\n"
#define ET "|%-15s|%-14ld|%-9s|%-8d|%-8d|%-14ld|%-6.1f|%-6.1f|%-6.1f|%-6.1f|%6.1f|%6.1f|%6.1f|\n绩点:                                                         |%-6.1f|%-6.1f|%-6.1f|%-6.1f|%-6.1f|\n",node->name,node->num,node->sex,node->age,node->bir,node->tel,node->score[0],node->score[1],node->score[2],node->score[3],node->score[4],node->sum,node->ave,node->gpa[0],node->gpa[1],node->gpa[2],node->gpa[3],node->gpa[4]

void clear(void)    //清屏函数
{
    system("clear");
}
typedef struct s
{
    long num;    //学号
    char name[20];    //姓名
    char sex[5];    //性别
    int age;    //年龄
    int bir;        //生日
        long tel;        //电话号码
    float score[5];    //五门成绩
    float ave;    //平均分
    float gpa[5];    //绩点
    float sum;    //总分数
    char pass[15];
    struct s * next;

}stu;

typedef struct passw
{
    long num;
    char pass[15];
    struct passw *next;
}DI;

stu * creat()        //创建链表
{
    stu* head,*node,*new_node;
    FILE *fp;
        fp=fopen("os.txt","w+");
        if((fp==NULL))
        {
                printf("加载失败!\n");
                exit(0);
        }

    head = node = (stu *)malloc(SI);
    new_node = (stu *)malloc(SI);
    printf("\n|学生姓名  |学号  |姓别 |年龄 |生日 |电话号码   |高数 |英语 |离散 |大物 |C语言:\n");
        scanf("%s %ld %s %d %d %ld %f %f %f %f %f",new_node->name,&new_node->num,new_node->sex,&new_node->age,&new_node->bir,&new_node->tel,&new_node->score[0],&new_node->score[1],&new_node->score[2],&new_node->score[3],&new_node->score[4]);
    int i;
        float sum=0;
        for (i=0;i<5;i++)
        {     
                sum+=new_node->score[i];
                if (new_node->score[i]<60)
                       new_node->gpa[i] = 0;
                else
                       new_node->gpa[i] = new_node->score[i]/10-5;
                
        }
        new_node->ave = sum/5;
    new_node->sum = sum;
while (new_node->num!=0)
{
    node->next = new_node;
    node = new_node;
    new_node = (stu *)malloc(SI);
    printf("\n|学生姓名  |学号  |姓别 |年龄 |生日 |电话号码   |高数 |英语 |离散 |大物 |C语言:\n");
        scanf("%s %ld %s %d %d %ld %f %f %f %f %f",new_node->name,&new_node->num,new_node->sex,&new_node->age,&new_node->bir,&new_node->tel,&new_node->score[0],&new_node->score[1],&new_node->score[2],&new_node->score[3],&new_node->score[4]);
        int i;
        float sum=0;
        for (i=0;i<5;i++)
        {
                sum+=new_node->score[i];
                if (new_node->score[i]<60)
                       new_node->gpa[i] = 0;
                
                else
                       new_node->gpa[i] = new_node->score[i]/10-5;
                
        }
        new_node->ave = sum/5;
    new_node->sum = sum;
}
node->next = NULL;
free(new_node);
fclose(fp);
return head;
}

void write(stu *head)
{
    stu *new_node;
    new_node = head->next;
    FILE *fp;
    if((fp = fopen("os.txt","w+"))==NULL)
    {
        printf("加载失败!\n");
        exit(0);
    }
while(new_node!=NULL)
{    
    fprintf(fp,"%-15s%-14ld%-9s%-8d%-8d%-14ld%-6.1f%-6.1f%-6.1f%-6.1f%-6.1f%-6.1f%-6.1f%-4.1f%-4.1f%-4.1f%-4.1f%-4.1f\n",new_node->name,new_node->num,new_node->sex,new_node->age,new_node->bir,new_node->tel,new_node->score[0],new_node->score[1],new_node->score[2],new_node->score[3],new_node->score[4],new_node->sum,new_node->ave,new_node->gpa[0],new_node->gpa[1],new_node->gpa[2],new_node->gpa[3],new_node->gpa[4]);
    new_node = new_node->next;

}
    fclose(fp);
}

stu *read(void)        //从文件中读取信息并创建链表
{
     stu* head,*node,*new_node;
    FILE *fp;
        fp=fopen("os.txt","r");
        if((fp==NULL))
        {
                printf("加载失败!\n");
                exit(0);
        }
    head = node = (stu *)malloc(SI);
        new_node = (stu *)malloc(SI);
    fscanf(fp,"%s %ld %s %d %d %ld %f %f %f %f %f %f %f %f %f %f %f %f",new_node->name,&new_node->num,new_node->sex,&new_node->age,&new_node->bir,&new_node->tel,&new_node->score[0],&new_node->score[1],&new_node->score[2],&new_node->score[3],&new_node->score[4],&new_node->sum,&new_node->ave,&new_node->gpa[0],&new_node->gpa[1],&new_node->gpa[2],&new_node->gpa[3],&new_node->gpa[4]);
    while(!feof(fp))
    {
        node->next = new_node;
        node = new_node;
        new_node = (stu *)malloc(SI);
         fscanf(fp,"\n%s %ld %s %d %d %ld %f %f %f %f %f %f %f %f %f %f %f %f",new_node->name,&new_node->num,new_node->sex,&new_node->age,&new_node->bir,&new_node->tel,&new_node->score[0],&new_node->score[1],&new_node->score[2],&new_node->score[3],&new_node->score[4],&new_node->sum,&new_node->ave,&new_node->gpa[0],&new_node->gpa[1],&new_node->gpa[2],&new_node->gpa[3],&new_node->gpa[4]);
    }
    node->next = NULL;
    free(new_node);
    fclose(fp);
    return(head);
}

stu *findnum(void)   //其中num为要查找的学生的学号
{
    long num;
    printf("查找的学号:");
    scanf("%ld",&num);
    stu *node;
    node = read();
    while (node->next!=NULL)
    {    
        node = node->next;
        if (node->num == num)
        {       printf(PT);
                        printf(ET);
            return node;
                }

    }
    printf("学生信息未找到!\n");
    return NULL;
    
}

stu *findname(void)   //其中num为要查找的学生的姓名
{
    char name[20];
    printf("查找的姓名:");
    scanf("%s",name);
        stu *node;
        node = read();
    int cmp;
        while (node->next!=NULL)
        {
        node = node->next;
                cmp = strcmp(name,node->name);
        if(cmp == 0)
        {    printf(PT);
                        printf(ET);
            return node;
        }
        }
        printf("学生信息未找到!\n");
    return 0;
        
}

void find()
{
    printf("\t\t\t1.姓名查找.\n\t\t\t2.学号查找.\n\t\t\t0.回到上层.\n");
    int i;
    scanf("%d",&i);
    switch(i)
    {
        case 1: findname();break;
        case 2: findnum();break;
        case 3: begin();break;
        default :printf("错误!\n");begin();
    }
}

stu *deletenum(void)
{
    long num;
    printf("输入要删除学生的学号:");
    scanf("%ld",&num);
    stu *head,*node,*no;
    head = no = read();
    node = no->next;
    while(node!=NULL)
       { if(node->num==num)
        {
            no->next = node->next;
            free(node);
            printf("删除成功!\n");
            write(head);
            return head;
        }
         no = node;
         node = node->next;
       }
       printf("删除失败!\n");
}

stu *deletename(void)
{
        char name[20];
        printf("输入要删除学生的姓名:");
        scanf("%s",name);
        stu *head,*node,*no;
        head = no = read();
        node = no->next;
        while(node!=NULL)
           { if(strcmp(node->name,name)==0)
                {
                        no->next = node->next;
                        free(node);
                        printf("删除成功!\n");
                        write(head);
                        return head;
                }
             no = node;
             node = node->next;
           }
           printf("删除失败!\n");
}

void delete()
{
        printf("\t\t\t1.按学号删除.\n\t\t\t2.按姓名查找.\n\t\t\t0.回到上层.\n");
        int i;
        scanf("%d",&i);
        switch(i)
        {
                case 1: deletenum();break;
                case 2: deletename();break;
                case 3: begin();break;
                default :printf("错误!\n");begin();
        }
}

stu* sortsum()
{
    stu *head = read();
    stu *p,*q,*pt,*t;
    t = (stu *)malloc(SI); // 创建临时结点
    t->next = head; // 临时结点作为链表临时头指针
    for(p = head; p->next!=NULL; p = p->next)
    {
        q = p->next;
        while(q->next!=NULL)
        {
            if(p->next->sum < q->next->sum)
            {
                pt = p->next;
                p->next = q->next;
                q->next = p->next->next;
                p->next->next = pt;
            }
            else q = q->next;
        }
    }
    head = t->next;
    free(t);
    write(head);
    return head;

}

stu* sortnum()
{
    stu *p,*q,*pt,*t,*head;
    head = read();
    t = (stu *)malloc(SI); //
    t->next = head; //
    for(p = head; p->next!=NULL; p = p->next)
    {
        q = p->next;
        while(q->next!=NULL)
    {
            if(p->next->num > q->next->num)
        {
                pt = p->next;
                p->next = q->next;
                q->next = p->next->next;
                p->next->next = pt;
            }
            else q = q->next;
        }
    }
    head = t->next;
    free(t);
    write(head);
}

stu* add(void)
{
    DI *fr();
    FILE *fp;
    if ((fp = fopen("pass.txt","a+"))==NULL)
        {
                printf("打开文件失败!\n");
                exit(0);
        }
    stu *head,*new_node,*node;
    DI *head1;
    DI *node1,*new_node1;
    head = read();
    head1 = fr();
    node = head->next;
    node1 = head1->next;
    while (node1->next!=NULL)
        node1 = node1->next;
    while(node->next!=NULL)
        node = node->next;
    new_node = (stu *)malloc(SI);
    printf("\n|学生姓名  |学号  |姓别 |年龄 |生日 |电话号码   |高数 |英语 |离散 |大物 |C语言:\n");
        scanf("%s %ld %s %d %d %ld %f %f %f %f %f",new_node->name,&new_node->num,new_node->sex,&new_node->age,&new_node->bir,&new_node->tel,&new_node->score[0],&new_node->score[1],&new_node->score[2],&new_node->score[3],&new_node->score[4]);
    int i;
        float sum=0;
        for (i=0;i<5;i++)
        {
                sum+=new_node->score[i];
                if (new_node->score[i]<60)
                       new_node->gpa[i] = 0;

                else
                       new_node->gpa[i] = new_node->score[i]/10-5;

        }
        new_node->ave = sum/5;
        new_node->sum = sum;
    new_node1 = (DI *)malloc(sizeof(DI));
    new_node1->num = new_node->num;
    strcpy(new_node1->pass,"000000");
    fprintf(fp,"%ld %s\n",node->num,new_node1->pass);
    while (new_node->num!=0)
{
    node->next = new_node;
    node1->next = new_node1;
    node = new_node;
    node1 = new_node1;
    new_node = (stu *)malloc(SI);
        printf("\n|学生姓名  |学号  |姓别 |年龄 |生日 |电话号码   |高数 |英语 |离散 |大物 |C语言:\n");
        scanf("%s %ld %s %d %d %ld %f %f %f %f %f",new_node->name,&new_node->num,new_node->sex,&new_node->age,&new_node->bir,&new_node->tel,&new_node->score[0],&new_node->score[1],&new_node->score[2],&new_node->score[3],&new_node->score[4]);
    int i;

        {
                sum+=new_node->score[i];
                if (new_node->score[i]<60)
                       new_node->gpa[i] = 0;

                else
                       new_node->gpa[i] = new_node->score[i]/10-5;

        }
        new_node->ave = sum/5;
        new_node->sum = sum;
    new_node1 = (DI *)malloc(sizeof(DI));
        new_node1->num = new_node->num;
        strcpy(new_node1->pass,"000000");
    fprintf(fp,"%ld %s\n",node->num,new_node1->pass);
}
    node->next = NULL;
    free(new_node);
    free(new_node1);
    write(head);
    fclose(fp);
    printf("文件插入保存成功");
    return head;
}

void mod()
{
    stu *new_node,*node,*head,*no;
    new_node = (stu *)malloc(SI);
    printf("输入要修改学生的信息\n|学生姓名  |学号  |姓别 |年龄 |生日 |电话号码   |高数 |英语 |离散 |大物 |C语言:\n");
    scanf("%s %ld %s %d %d %ld %f %f %f %f %f",new_node->name,&new_node->num,new_node->sex,&new_node->age,&new_node->bir,&new_node->tel,&new_node->score[0],&new_node->score[1],&new_node->score[2],&new_node->score[3],&new_node->score[4]);
    int i;
        float sum=0;
        for (i=0;i<5;i++)
        {
                sum+=new_node->score[i];
                if (new_node->score[i]<60)
                       new_node->gpa[i] = 0;

                else
                       new_node->gpa[i] = new_node->score[i]/10-5;

        }
        new_node->ave = sum/5;
        new_node->sum = sum;
    no = head = read();
    node = head->next;
    while (node!=NULL)
        {
            if (node->num == new_node->num)
            {    new_node->next = node->next;
                no->next = new_node;
                free(node);
                printf("学生信息修改成功!\n");
                
            }
        node = node->next;
        no = no->next;
        }
    write(head);
    
}

void print(stu *node)
{
    while(node!=NULL)
    {
    if(node->num == 0)
    {    node= node->next;
        continue;
    }
    printf(ET);
    node = node->next;
    
    }    
}

void upst(void)
{
    printf("\t\t任意键返回.\n");
    getchar();
    getchar();
}

void sta(void)
{
    sortsum();
    stu *head,*node,*new_node;
    head = read();
    int a[5]={0};
    node = head->next;
    while (node!=NULL)
    {
        if (node->gpa[0]==0) a[0]++;
        if (node->gpa[1]==0) a[1]++;
        if (node->gpa[2]==0) a[2]++;
        if (node->gpa[3]==0) a[3]++;
        if (node->gpa[4]==0) a[4]++;
        node = node->next;

    }
    print(head);
    printf("其中高数挂科%d个.\n英语挂科%d个.\n离散挂科%d个.\n大物挂科%d个.\nC语言挂科%d个.\n",a[0],a[1],a[2],a[3],a[4]);
    node = head->next;
    printf("以下是成绩最高学生的信息:\n");
    printf(PT);
    printf(ET);

}

int repas(void)
{
    stu *head,*node;
    head = read();
    FILE *fp;
    if ((fp = fopen("pass.txt","w+"))==NULL)
    {
        printf("打开文件失败!\n");
        exit(0);
    }
    node = head->next;
    while(node!=NULL)
    {
        strcpy(node->pass,"000000");
        fprintf(fp,"%ld %s\n",node->num,node->pass);
        node = node->next;
    }
    printf("密码重置成功!\n");
    fclose(fp);
    sleep(1);
    clear();
}

DI *fr()
{
    FILE *fp;
    if((fp = fopen("pass.txt","r"))==NULL)
    {
        printf("文件读取失败!\n");
        exit(0);
    }
    DI *head,*node,*new_node;
    head = node = (DI *)malloc(sizeof(DI));
    new_node = (DI *)malloc(sizeof(DI));
    fscanf(fp,"%ld %s",&new_node->num,new_node->pass);
    while (!feof(fp))
    {
        node->next = new_node;
        node = new_node;
        new_node = (DI *)malloc(sizeof(DI));
        fscanf(fp,"\n%ld %s",&new_node->num,new_node->pass);
    }
    node->next = NULL;
    free(new_node);
    fclose(fp);
    return head;
}
void fw(DI *head)
{
    FILE *fp;
        if((fp = fopen("pass.txt","w+"))==NULL)
        {
                printf("文件读取失败!\n");
                exit(0);
        }

    DI *node;
    node = head->next;
    while(node!=NULL)
    {
        fprintf(fp,"%ld %s\n",node->num,node->pass);
        node = node->next;
    }
    fclose(fp);
}

int password()
{
    DI *head1,*node1;
    long n;
    int i=3;
    char p[15];
    head1 = fr();
    node1 = head1->next;
while(1)
{
    printf("\t\t用户名:");
                scanf("%ld",&n);
                printf("\n\t\t密码:");system("stty -echo");
                scanf("%s",p);system("stty echo");
    while(node1!=NULL)
    {
        if (node1->num==n&&strcmp(node1->pass,p)==0)
        {
            while (1)
            {
            studbe(node1->num);
            }
            return 1;
            
        }
        node1 = node1->next;
    

    }
        i--;
                if (i==0)
                        exit(1);
        printf("您还可以输入%d次!\n",i);
        node1 = head1->next;



}        
}

void stud(long num)
{
    stu *head,*node;
    int i=1,j,lo=0;
    sortsum();
    head = read();
    node = head->next;
    while(node->num!=num)
    {    i++;
        node = node->next;
    }
    for (j=0;j<5;j++)
    {
        if(node->gpa[j]==0)
            lo++;
    }
    printf("PT");
    printf(ET);
    printf("您的成绩在整个年级排第%d位.\n有挂科%d门.\n",i,lo);
}

int password1()
{
    char pass[20],pas[20];
    int i=3;
    clear();
    FILE *fp;
    if((fp = fopen("pass","r"))==NULL)
        {
                printf("文件读取失败!\n");
                exit(0);
        }
    fscanf(fp,"%s",pas);
    while(1)
    {    printf("\t\t账号:admin");
            printf("\t\t密码:");system("stty -echo");
            scanf("%s",pass);system("stty echo");
        if(strcmp(pas,pass)==0)
        {    while (1)
                begin();
                return 1;
        }
        i--;
        if (i==0)
            exit(0);
        printf("您还有%d次输入机会!\n",i);

    }
    

    

}

void pas(long num)
{
    clear();
    char a[20],b[20],c[20];
    DI *head,*node;
    head = fr();
    printf("\t\t输入原始密码:");system("stty -echo");
    scanf("%s",a);system("stty echo");
    printf("\n\t\t输入新密码:");system("stty -echo");
    scanf("%s",b);system("stty echo");
        printf("\n\t\t再次输入新密码:");system("stty -echo");
    scanf("%s",c);system("stty echo");
    node = head->next;
    while(node!=NULL)
    {
        if (node->num==num)
            {if (strcmp(node->pass,a)==0&&strcmp(b,c)==0)
            {    strcpy(node->pass,b);
                fw(head);
                printf("密码修改成功!\n");
                break;
            }
            else printf("原密码输入错误或两次新密码不一致,请重试!\n");}
        node = node->next;
        
    }    
}

studbe(long num)
{
clear();
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t*******************************************************************************************************\t\t\n");
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t========|||       **    **               *************                   *         *****    |||========\t\t\n");
printf("\t\t\t========|||    **************                *   *                       *         *  *     |||========\t\t\n");
printf("\t\t\t========|||   ****************           *************             * * * * * * *   * *      |||========\t\t\n");
printf("\t\t\t========|||    **************            *   *   *   *             *     *     *   *  *     |||========\t\t\n");
printf("\t\t\t========|||      **********              * * *   * * *             * * * * * * *   * **     |||========\t\t\n");
printf("\t\t\t========|||        ******                *           *             *     *     *   *        |||========\t\t\n");
printf("\t\t\t========|||          **                  * * * * * * *             * * * * * * *   *        |||========\t\t\n");
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t******************************====================================*************************************\t\t\n");
printf("\t\t\t===========================|||欢迎来到西安邮电大学学生信息查询系统|||==================================\t\t\n");
printf("\t\t\t===========================|||              请选择                |||==================================\t\t\n");
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t                           ||| 1.查询自己的信息.                |||\n");
printf("\t\t\t                           ||| 2.修改密码.                      |||\n");
printf("\t\t\t                           ||| 0.退出.                          |||\n");
printf("\t\t\t                           ========================================\n");
int i;
printf("\n\t\t\t");
scanf("%d",&i);
switch(i)
        {
                case 1 : clear();stud(num);upst();break;
                case 2 : clear();pas(num);upst();break;
        case 0 : printf("\t\t\t谢谢使用,再见!\n");system("sl");clear();exit(0);
    }
}

void admin(void)
{

        clear();
        char a[20],b[20],c[20],d[20];
    FILE *fp;
     if ((fp = fopen("pass","r"))==NULL)
        {
                printf("打开文件失败!\n");
                exit(0);
        }
    fscanf(fp,"%s",d);
    fclose(fp);
        printf("\t\t输入原始密码:");system("stty -echo");
        scanf("%s",a);system("stty echo");
        printf("\n\t\t输入新密码:");system("stty -echo");
        scanf("%s",b);system("stty echo");
        printf("\n\t\t再次输入新密码:");system("stty -echo");
        scanf("%s",c);system("stty echo");
                        if (strcmp(d,a)==0&&strcmp(b,c)==0)
                            {
                fp = fopen("pass","w+");
                                fprintf(fp,"%s",c);
                                printf("密码修改成功!\n");
                            }
                        else printf("原密码输入错误或两次新密码不一致,请重试!\n");
    fclose(fp);
        


}

int pa(void)
{
char pass[20],pas[20];
        int i=3;

FILE *fp;
        if((fp = fopen("pass","r"))==NULL)
        {
                printf("文件读取失败!\n");
                exit(0);
        }
        fscanf(fp,"%s",pas);
        while(1)
        {       printf("\t\t账号:admin");
                printf("\t\t密码:");system("stty -echo");
                scanf("%s",pass);system("stty echo");
                if(strcmp(pas,pass)==0)
                {    
                                creat();
                                return 1;
                }
                i--;
                if (i==0)
                        exit(0);
                printf("您还有%d次输入机会!\n",i);
}    
}

void repass()
{
    clear();
    int i;
    printf("\t\t1.更改管理员密码\n\t\t2.重置学生登录密码(慎重).\n\t\t3.删除所有学生信息并重新创建(慎重)\n\t\t0.返回上一层\n\t\t");
    scanf("%d",&i);
    switch(i)
        {
                case 1 : clear();admin();upst();break;
                case 2 : clear();repas();upst();break;
        case 3 : clear();pa();break;
                case 0 : begin();break;
        }


}

begin()
{
stu *head,node,new_node;
clear();
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t*******************************************************************************************************\t\t\n");
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t========|||       **    **               *************                   *         *****    |||========\t\t\n");
printf("\t\t\t========|||    **************                *   *                       *         *  *     |||========\t\t\n");
printf("\t\t\t========|||   ****************           *************             * * * * * * *   * *      |||========\t\t\n");
printf("\t\t\t========|||    **************            *   *   *   *             *     *     *   *  *     |||========\t\t\n");
printf("\t\t\t========|||      **********              * * *   * * *             * * * * * * *   * **     |||========\t\t\n");
printf("\t\t\t========|||        ******                *           *             *     *     *   *        |||========\t\t\n");
printf("\t\t\t========|||          **                  * * * * * * *             * * * * * * *   *        |||========\t\t\n");
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t******************************====================================*************************************\t\t\n");
printf("\t\t\t===========================|||欢迎来到西安邮电大学学生信息管理系统|||==================================\t\t\n");
printf("\t\t\t===========================|||              请选择                |||==================================\t\t\n");
printf("\t\t\t=======================================================================================================\t\t\n");
printf("\t\t\t                           ||| 1.预览所有学生信息.                |||\n");
printf("\t\t\t                           ||| 2.查找学生信息.                    |||\n");
printf("\t\t\t                           ||| 3.添加学生信息.                    |||\n");
printf("\t\t\t                           ||| 4.删除学生信息.                    |||\n");
printf("\t\t\t                           ||| 5.修改学生信息.                    |||\n");
printf("\t\t\t                           ||| 6.统计学生信息.                    |||\n");
printf("\t\t\t                           ||| 7.重置.                            |||\n");
printf("\t\t\t                           ||| 0.退出程序                         |||\n");
printf("\t\t\t                           ==========================================\n");
int i;
printf("\t\t\t");
scanf("%d",&i);
switch(i)
        {
                case 1 : clear();sortnum();head = read();print(head);upst();break;
                case 2 : clear();find();upst();break;
                case 3 : clear();add();upst();break;
                case 4 : clear();delete();upst();break;
                case 5 : clear();mod();upst();break;
                case 6 : clear();sta();upst();break;
                case 7 : clear();repass();break;
                case 0 : printf("\t\t\t谢谢使用,再见!\n");system("sl");clear();exit(0);
        }

}

int main(void)
{
    clear();
        printf("\t\t<选择登陆方式>\n\t\t1.管理员登陆.\n\t\t2.学生登陆.\n\t\t0.退出程序");
    int i;
    printf("\t\t\t");
    scanf("%d",&i);
    switch(i)
        {
                case 1 : clear();password1();break;
                case 2 : clear();password();break;
        case 0 : printf("谢谢使用!\n");sleep(3);exit(0);
    }
}


你可能感兴趣的:(c)