C++基础学生管理系统

 更新时间:2020年04月08日 09:58:12   作者:2996371275  
这篇文章主要介绍了C++基础学生管理系统的相关资料,包括了文件处理代码,链表处理代码,以及自定义代码,主函数自定义,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

本文实例为大家分享了C++基础学生管理系统的实现代码,供大家参考,具体内容如下

适用于c++6.0,codeblocks等常用工具

1. 链表处理部分

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
 
#include"linklist.h"
#include"elem.h"
 
 
void dispnode(linklist h)
{
 node *p;
 p=h->next;
 while(p)
 {
 dispelem(p);
 p=p->next;
 }
 
}
 
int inputnode(linklist h,T e)
{
 node *p;
 node *q;
 p=h;
 while(p->next&& (p->next->data).id<=e.id)
 {
 if((p->next->data).id==e.id)
  return 0;
 p=p->next;
 }
 q=(node*)malloc(sizeof(node));
 q->data=e;
 q->next=p->next;
 p->next=q;
 return 1;
}
 
int delnode(linklist h,int id)
{
 node *p;
 p=h;
 while(p->next&&(p->next->data).id!=id)
 p=p->next;
 if(p->next)
 {
 node *t=p->next;
 p->next=t->next;
 free(t);
 return 1;
 
 }
 else
 return 0;
 
}
 
node* searchname(linklist h,char name[])
{
 node *p;
 p=h-next;
 while( p && strcmp((p->data).name ,name)!=0)
 p=p->next;
 return p;
}
 
node* searchid(linklist h,int id)
{
 node *p;
 p=h->next;
 while( p->next && (p->next->data).id <= e.id )
 p=p->next;
 return p;
}

2. 数据处理部分    

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
 
#include"linklist.h"
#include"elem.h"
 
 
void dispnode(linklist h)
{
 node *p;
 p=h->next;
 while(p)
 {
 dispelem(p);
 p=p->next;
 }
 
}
 
int inputnode(linklist h,T e)
{
 node *p;
 node *q;
 p=h;
 while(p->next&& (p->next->data).id<=e.id)
 {
 if((p->next->data).id==e.id)
  return 0;
 p=p->next;
 }
 q=(node*)malloc(sizeof(node));
 q->data=e;
 q->next=p->next;
 p->next=q;
 return 1;
}
 
int delnode(linklist h,int id)
{
 node *p;
 p=h;
 while(p->next&&(p->next->data).id!=id)
 p=p->next;
 if(p->next)
 {
 node *t=p->next;
 p->next=t->next;
 free(t);
 return 1;
 
 }
 else
 return 0;
 
 
 
 
}
 
node* searchname(linklist h,char name[])
{
 node *p;
 p=h-next;
 while( p && strcmp((p->data).name ,name)!=0)
 p=p->next;
 return p;
}
 
node* searchid(linklist h,int id)
{
 node *p;
 p=h->next;
 while( p->next && (p->next->data).id <= e.id )
 p=p->next;
 return p;
}


3. 文件处理部分    

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
 
#include"linklist.h"
#include"elem.h"
 
 
void dispnode(linklist h)
{
 node *p;
 p=h->next;
 while(p)
 {
 dispelem(p);
 p=p->next;
 }
 
}
 
int inputnode(linklist h,T e)
{
 node *p;
 node *q;
 p=h;
 while(p->next&& (p->next->data).id<=e.id)
 {
 if((p->next->data).id==e.id)
  return 0;
 p=p->next;
 }
 q=(node*)malloc(sizeof(node));
 q->data=e;
 q->next=p->next;
 p->next=q;
 return 1;
}
 
int delnode(linklist h,int id)
{
 node *p;
 p=h;
 while(p->next&&(p->next->data).id!=id)
 p=p->next;
 if(p->next)
 {
 node *t=p->next;
 p->next=t->next;
 free(t);
 return 1;
 
 }
 else
 return 0;
 
 
 
 
}
 
node* searchname(linklist h,char name[])
{
 node *p;
 p=h-next;
 while( p && strcmp((p->data).name ,name)!=0)
 p=p->next;
 return p;
}
 
node* searchid(linklist h,int id)
{
 node *p;
 p=h->next;
 while( p->next && (p->next->data).id <= e.id )
 p=p->next;
 return p;
}

4. 主菜单自定义部分

#include <stdio.h>
#include <stdlib.h>
 
 
#include "linklist.h"
#include "elem.h"
#include "fileop.h"
 
void mainmenu();
 
void searchlinklist(linlist h)
{
 linklist h;
 h=(linklist)malloc(sizeof(node));
 h->next=NULL;
 loadfile(h);
 mainmenu(h);
 savefile(h);
 printf("\n");
 return 0;
}
void mainmenu()
{
 node *p;
 int id;
 T e;
 int select;
 int count=1;
 do
 {
 printf("\n");
 printf(" ----------------¡¶SSMGS OS¡· ---------------\n");
 printf(" 1 displaying 2 searching 3 adding 4 deleting\n\n");
 printf("   5 changing 6 extiting \n");
 printf(" --------------------welcome ------------------------\n");
 printf("please input your select: ");
 scanf("%d", &select);
 switch(select)
 {
 case 1:
  dispnode(h);
  break;
 case 2:
  searchlinlist(h);
  break;
 case 3:
  inputelem(&e);
  if(inputnode(h,e))
  printf("succeed\n");
  else
  printf("failed\n");
  break;
 case 4:
  printf("please input id:");
  scanf("%d",&id);
 
  break;
 case 5://功能引用
  break;
 case 6://功能引用
  count=0;
  break;
 }
 
 }while(count);
 
}

5.头文件集合部分

elem.h部分

#ifndef LINKLIST_H_INCLUDED
#define LINKLIST_H_INCLUDED
 
#include"elem.h"
 
 
typedef struct node
{
 T data;
 struct node *next;
}node;
 
typedef node* linklist;
 
void dispnode(linklist h);
 
int inputnode(linklist h,T e);
 
int delnode(linklist h,int id);
 
node* searchname(linklist h,char name[]);
 
node* searchid(linklist h,int id);
 
 
 
 
 
 
#endif // LINKLIST_H_INCLUDED
 
fileop.h部分
 
#ifndef FILEOP_H_INCLUDED
#define FILEOP_H_INCLUDED
 
#include"linklist.h"
 
void savefile(linklist h);
 
 
void loadfile(linklist h);
 
 
 
#endif // FILEOP_H_INCLUDED
 
 
linklist.h部分
 
#ifndef LINKLIST_H_INCLUDED
#define LINKLIST_H_INCLUDED
 
#include"elem.h"
 
 
typedef struct node
{
 T data;
 struct node *next;
}node;
 
typedef node* linklist;
 
void dispnode(linklist h);
 
int inputnode(linklist h,T e);
 
int delnode(linklist h,int id);
 
node* searchname(linklist h,char name[]);
 
node* searchid(linklist h,int id);
 
#endif // LINKLIST_H_INCLUDED

推荐几篇文章:

C++实现简单的图书管理系统

C++实现简单的职工信息管理系统

C++基础学生管理系统

关于管理系统的更多内容请点击《管理系统专题》进行学习

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持程序员之家。

相关文章

  • C语言数据在内存中的存储详解

    C语言数据在内存中的存储详解

    本篇文章是C语言编程篇,主要为大家介绍C语言编程中数据在内存中存储解析,有需要的朋友可以借鉴参考下,希望可以有所帮助
    2021-09-09
  • 一文读懂C++中的继承之菱形继承(案例分析)

    一文读懂C++中的继承之菱形继承(案例分析)

    这篇文章主要介绍了C++中的继承之菱形继承的相关知识,通过案例给大家详细分析介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2021-04-04
  • C语言?详解如何删除有序数组中的重复项

    C语言?详解如何删除有序数组中的重复项

    数组不擅长插入(添加)和删除元素。数组的优点在于它是连续的,所以查找数据速度很快。但这也是它的一个缺点。正因为它是连续的,所以当插入一个元素时,插入点后所有的元素全部都要向后移;而删除一个元素时,删除点后所有的元素全部都要向前移
    2022-03-03
  • C++?string如何获取文件路径文件名、文件路径、文件后缀(两种方式)

    C++?string如何获取文件路径文件名、文件路径、文件后缀(两种方式)

    这篇文章主要介绍了C++?string如何获取文件路径文件名、文件路径、文件后缀(两种方式),具有很好的参考价值,希望对大家有所帮助。
    2023-06-06
  • 用C语言实现从文本文件中读取数据后进行排序的功能

    用C语言实现从文本文件中读取数据后进行排序的功能

    这是一个十分可靠的程序,这个程序的查错能力非常强悍。程序包含了文件操作,归并排序和字符串输入等多种技术。对大家学习C语言很有帮助,有需要的一起来看看。
    2016-08-08
  • Qt绘制时钟效果

    Qt绘制时钟效果

    这篇文章主要为大家详细介绍了Qt绘制时钟效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • C/C++ 中怎样使用SetConsoleTextAttribute()函数来控制输出字符的颜色

    C/C++ 中怎样使用SetConsoleTextAttribute()函数来控制输出字符的颜色

    这篇文章主要介绍了C/C++ 中如何使用SetConsoleTextAttribute()函数来控制输出字符的颜色,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • C语言数据结构之线性表的链式存储结构

    C语言数据结构之线性表的链式存储结构

    线性表是最基本、最简单、也是最常用的一种数据结构。线性表(linear list)是数据结构的一种,一个线性表是n个具有相同特性的数据元素的有限序列,这篇文章带你学习下线性表的链式存储结构
    2021-11-11
  • 浅谈Linux环境下并发编程中C语言fork()函数的使用

    浅谈Linux环境下并发编程中C语言fork()函数的使用

    fork函数在Linux中可以创建子进程即一个新的进程,这里我们根据实例来浅谈Linux环境下并发编程中C语言fork()函数的使用,需要的朋友可以参考下
    2016-06-06
  • Visual Studio 2022卡死分析

    Visual Studio 2022卡死分析

    本文主要介绍了Visual Studio 2022卡死分析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06

最新评论

?


http://www.vxiaotou.com