• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C++基础学生管理系统

C++基础学生管理系统

作者:2996371275 字体:[增加 减小] 来源:互联网 时间:2017-05-28

2996371275 通过本文主要向大家介绍了c++基础,c++基础代码,c++基础教程,c++语言基础教程,c++程序设计基础等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例为大家分享了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;
}
</div>

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;
}
</div>


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;
}
</div>

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);
 
}
</div>

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
</div>

以上就是本文的全部内容,希望对大家学习C++语言有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C++基础学生管理系统
  • C++基础之this指针与另一种“多态”

相关文章

  • 2017-05-28老生常谈C++的单例模式与线程安全单例模式(懒汉/饿汉)
  • 2017-05-28C++编译器无法捕捉到的8种错误实例分析
  • 2017-05-28使用WindowsAPI获取录音音频的方法
  • 2017-05-28如何查看进程实际的内存占用情况详解
  • 2017-05-28VC程序设计小技巧20例
  • 2017-05-28详解C++ 拷贝构造函数和赋值运算符
  • 2017-12-31数据结构 哈希表设计
  • 2017-05-28C++求阶乘的两种方法
  • 2017-05-28C++中求旋转数组中的最小数字(经典面试题)
  • 2017-05-28C++实现自顶向下的归并排序算法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C#使用反射加载多个程序集的实现方法
    • C语言求向量和的两则问题解答分享
    • C++ 智能指针深入解析
    • 用C语言来实现一个简单的虚拟机
    • 详解C语言中symlink()函数和readlink()函数的使用
    • C++中宏的使用问题详解
    • C++遗传算法类文件实例分析
    • 基于C++ cin、cin.get()、cin.getline()、getline()、gets()函数的使用详解
    • C语言中6组指针和自增运算符结合方式的运算顺序问题
    • C语言的isatty函数和ttyname函数以及sendmsg函数用法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有