⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 学生信息管理.c

📁 用C语言编写的学生信息管理小程序,可以将记录导为文件保存
💻 C
字号:
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
int shoudsave=0; //
struct student
{
 char  num[10];//学号
 char name[20];
 char sex[4];
 int sum;
 int absence;
 int come;
};

typedef struct node
{
 struct student data;
 struct node *next;
}Node,*Link;


void menu()
{
 printf("\n");
 printf("\t\t***************************\n");
 printf("\t\t\t1输入学生信息\n");
 printf("\t\t\t2删除学生信息\n");
 printf("\t\t\t3查询学生信息\n");
 printf("\t\t\t4修改学生信息\n");
 printf("\t\t\t5显示学生信息\n");
 printf("\t\t\t6统计排序\n");
 printf("\t\t\t7保存学生信息\n");
 printf("\t\t\t8获取帮助信息\n");
 printf("\t\t\t0退出系统\n");
 printf("\t\t***************************\n");
 printf("\n");
}

void printstart()
{
 printf("\n");
}
void Wrong()
{
 printf("\n提示:输入错误!\n");
 printf("\n");
}

void Nofind()
{
 printf("\n提示:没有找到该学生!\n");
 printf("\n");
}

void printc() // 本函数用于输出中文
{
 printf("  学号\t    姓名      性别 总课时 缺勤 出勤\n");
 printf("\n");
}

void printe(Node *p)//本函数用于输出英文
{
 printf("%-12s%s\t%s\t%d\t%d\t%d\t   %d\t %d\n",p->data.num,p->data.name,p->data.sex,p->data.sum,p->data.absence,p->data.come);
}

Node* Locate(Link l,char findmess[],char nameornum[])  //该函数用于定位连表中符合要求的接点,并返回该指针
{
 Node *r;
 if(strcmp(nameornum,"num")==0) //按学号查询
 {
  r=l->next;
  while(r)
  {
   if(strcmp(r->data.num,findmess)==0)
    return r;
   r=r->next;
  }
 }
 else if(strcmp(nameornum,"name")==0)  //按姓名查询
 {
  r=l->next;
  while(r)
  {
   if(strcmp(r->data.name,findmess)==0)
    return r;
   r=r->next;
  }
 }
 return 0;
}

void Add(Link l)  //增加学生
{
 Node *p,*r,*s;
 char num[10];
 r=l;
 s=l->next;
 while(r->next!=NULL)
  r=r->next; //将指针置于最末尾
 while(1)
 {
  printf("\n");
  printf("请你输入学号(以'0'返回上一级菜单:)");
  scanf("%s",num);
  printf("\n");
  if(strcmp(num,"0")==0)
   break;
  while(s)
  {
   if(strcmp(s->data.num,num)==0)
   {
    printf("\n");
    printf("提示:学号为'%s'的学生已经存在,若要修改请你选择'4 修改'!\n",num);
    printstart();
    printc();
    printe(s);
    printstart();
    printf("\n");
    return;
   }
   s=s->next;
  }

  p=(Node *)malloc(sizeof(Node));

  strcpy(p->data.num,num);
  printf("请你输入姓名:");
  scanf("%s",p->data.name);
  getchar();
  printf("\n");
  printf("请你输入性别:");
  scanf("%s",p->data.sex);
  getchar();
  printf("\n");
  printf("请你输总课时数:");
  scanf("%d",&p->data.sum);
  getchar();
  printf("\n");
  printf("请你输入缺勤课时数:");
  scanf("%d",&p->data.absence);
  getchar();
  printf("\n");
  printf("请你输入出勤课时数:");
  scanf("%d",&p->data.come);
  getchar();
  //信息输入已经完成
  p->next=NULL;
  r->next=p;
  r=p;
  shoudsave=1;

 }
}

void Qur(Link l) //查询学生
{
 int sel;
 char findmess[20];
 Node *p;
 if(!l->next)
 {
  printf("\n提示:没有资料可以查询!\n");
  printf("\n");
  return;

 }
 printf("\n1按学号查找\n\n2按姓名查找\n");
 scanf("%d",&sel);
 if(sel==1)//学号
 {
  printf("请你输入要查找的学号:");
  scanf("%s",findmess);
  p=Locate(l,findmess,"num");
  if(p)
  {
   printf("\t\t\t\t查找结果\n");
   printstart();
   printc();
   printe(p);
   printstart();
  }
  else
   Nofind();
 }
 else if(sel==2) //姓名
 {
  printf("请你输入要查找的姓名:");
  scanf("%s",findmess);
  p=Locate(l,findmess,"name");
  if(p)
  {
   printf("\t\t\t\t查找结果\n");
   printstart();
   printc();
   printe(p);
   printstart();
  }
  else
   Nofind();
 }
 else
  Wrong();

}

void Del(Link l) //删除
{
 int sel;
 Node *p,*r;
 char findmess[20];
 if(!l->next)
 {
  printf("\n提示:没有资料可以删除!\n");
  printf("\n");
  return;
 }
 printf("\n1按学号删除\n\n2按姓名删除\n");
 scanf("%d",&sel);
 if(sel==1)
 {
  printf("请你输入要删除的学号:");
  scanf("%s",findmess);
  p=Locate(l,findmess,"num");
  if(p)
  {
   r=l;
   while(r->next!=p)
    r=r->next;
   r->next=p->next;
   free(p);
   printf("\n提示:该学生已经成功删除!\n");
   printf("\n");
   shoudsave=1;
  }
  else
   Nofind();
 }
 else if(sel==2)
 {
  printf("请你输入要删除的姓名:");
  scanf("%s",findmess);
  p=Locate(l,findmess,"name");
  if(p)
  {
   r=l;
   while(r->next!=p)
    r=r->next;
   r->next=p->next;
   free(p);
   printf("\n提示:该学生已经成功删除!\n");
   shoudsave=1;
  }
  else
   Nofind();
 }
 else
  Wrong();
}

void Modify(Link l)
{
 Node *p;
 char findmess[20];
 if(!l->next)
 {
  printf("\n提示:没有资料可以修改!\n");
  printf("\n");
  return;
 }
 printf("请你输入要修改的学生学号:");
 scanf("%s",findmess);
 p=Locate(l,findmess,"num");
 if(p)
 {
  printf("请你输入新的总课时数:",p->data.sum);
  scanf("%d",&p->data.sum);
  getchar();
  printf("\n");
  printf("请你输入缺勤课时数:",p->data.absence);
  scanf("%d",&p->data.absence);
  getchar();
  printf("\n");
  printf("请你输入新的出勤课时数):",p->data.come);
  scanf("%d",&p->data.come);
  getchar();
  printf("\n");
  printf("\n提示:资料修改成功!\n");
  shoudsave=1;
 }
 else
  Nofind();

}

void Disp(Link l)
{
 int count=0;
 Node *p;
 p=l->next;

 if(!p)
 {
  printf("\n提示:没有资料可以显示!\n");
  return;
 }
 printf("\t\t\t\t显示结果\n");
 printstart();
 printc();
 printf("\n");
 while(p)
 {
  printe(p);
  p=p->next;
 }
 printstart();
 printf("\n");
}

void Tongji(Link l)
{
 Node *pc,*pa; //用于指向分数最高的接点
 Node *r=l->next;
 if(!r)
 {
  printf("\n提示:没有资料可以统计!\n");
  return ;
 }
 pc=pa=r;
 while(r)
 {
  if(r->data.absence>=pa->data.absence)
   pa=r;
  if(r->data.come>=pc->data.come)
   pc=r;
   
  r=r->next;
 }
 printf("<<<<<<<<<<<<<<<<<<<<<<统计结果>>>>>>>>>>>>>>>>>>>>>>>\n");
 printf("缺勤次数最多者:\t%s %d分\n",pa->data.name,pa->data.absence);
 printf("出勤次数最多者:\t%s %d分\n",pc->data.name,pc->data.come);
    printstart();
}

void Sort(Link l)
{
 Link ll;
 Node *p,*rr,*s;

 ll=(Link)malloc(sizeof(Node)); //用于做新的连表
 ll->next=NULL;

 if(l->next==NULL)
 {
  printf("\n提示:没有资料可以排序!\n");
  return ;
 }
 p=l->next;
 while(p)
 {
  s=(Node*)malloc(sizeof(Node)); //新建接点用于保存信息
  s->data=p->data;
  s->next=NULL;

  rr=ll;
  while(rr->next!=NULL && rr->next->data.absence>=p->data.absence)
   rr=rr->next;
  if(rr->next==NULL)
   rr->next=s;
  else
  {
   s->next=rr->next;
   rr->next=s;
  }
  p=p->next;
 }
 free(l);
 l->next=ll->next;
 printf("\n提示:排序已经完成!\n");
}

void Save(Link l)
{
 FILE* fp;
 Node *p;
 int flag=1,count=0;
 fp=fopen("...\student","wb");
 if(fp==NULL)
 {
  printf("\n提示:重新打开文件时发生错误!\n");
  exit(1);
 }
 p=l->next;

 while(p)
 {
  if(fwrite(p,sizeof(Node),1,fp)==1)
  {
   p=p->next;
   count++;
  }
  else
  {
   flag=0;
   break;
  }
 }
 if(flag)
 {
  printf("\n提示:文件保存成功!(有%d条记录已经保存.)\n",count);
  shoudsave=0;
 }
 fclose(fp);
}

void main()
{
 Link l;//链表
 FILE *fp; //文件指针
 int sel;
 char ch;

 int count=0;
 Node *p,*r;
 printf("\n");
 printf("\n");
 printf("\t<<<<<<<<<<<<<<<<欢迎使用学生考勤管理系统>>>>>>>>>>>>>>>>>\n\n");
 l=(Node*)malloc(sizeof(Node));
 l->next=NULL;
 r=l;

 fp=fopen("...\student","ab+");
 if(fp==NULL)
 {
  printf("\n提示:文件无法打开!\n");
  exit(0);
 }
 printf("\n提示:文件已经打开,正在导入记录,请等待;\n");

 while(!feof(fp))
 {
  p=(Node*)malloc(sizeof(Node));
  if(fread(p,sizeof(Node),1,fp)==1) //将文件的内容放入接点中
  {
   p->next=NULL;
   r->next=p;
   r=p; //将该接点挂入链中
   count++;
  }
 }

 fclose(fp); //关闭文件
 printf("\n提示:记录导入完毕,共导入记录%d条记录.\n",count);
 menu();
 while(1)
 {
  printf("请你选择操作:");
  scanf("%d",&sel);

  if(sel==0)
  {
   if(shoudsave==1)
   { getchar();
    printf("\n提示:资料已经改动,是否将改动保存到文件中(y/n)?\n");
    scanf("%c",&ch);
    if(ch=='y'||ch=='Y')
     Save(l);
   }
   printf("\n提示:你已经退出系统,再见!\n");
   break;
  }
  switch(sel)
  {
  case 1:Add(l);break; //增加学生
  case 2:Del(l);break;//删除学生
  case 3:Qur(l);break;//查询学生
  case 4:Modify(l);break;//修改学生
  case 5:Disp(l);break;//显示
  case 6:Tongji(l);break;//统计排序
  case 7:Save(l);break;//保存
  case 8:printf("\t\t\t<<<<<<<<<<<帮助信息>>>>>>>>>>>>>>>>\n");menu();break;
  default: Wrong();getchar();break;
  }
 }
}


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -