C++基礎(chǔ)學生管理系統(tǒng)
本文實例為大家分享了C++基礎(chǔ)學生管理系統(tǒng)的實現(xiàn)代碼,供大家參考,具體內(nèi)容如下
適用于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. 數(shù)據(jù)處理部分
#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
推薦幾篇文章:
關(guān)于管理系統(tǒng)的更多內(nèi)容請點擊《管理系統(tǒng)專題》進行學習
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++?string如何獲取文件路徑文件名、文件路徑、文件后綴(兩種方式)
這篇文章主要介紹了C++?string如何獲取文件路徑文件名、文件路徑、文件后綴(兩種方式),具有很好的參考價值,希望對大家有所幫助。2023-06-06用C語言實現(xiàn)從文本文件中讀取數(shù)據(jù)后進行排序的功能
這是一個十分可靠的程序,這個程序的查錯能力非常強悍。程序包含了文件操作,歸并排序和字符串輸入等多種技術(shù)。對大家學習C語言很有幫助,有需要的一起來看看。2016-08-08C/C++ 中怎樣使用SetConsoleTextAttribute()函數(shù)來控制輸出字符的顏色
這篇文章主要介紹了C/C++ 中如何使用SetConsoleTextAttribute()函數(shù)來控制輸出字符的顏色,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03C語言數(shù)據(jù)結(jié)構(gòu)之線性表的鏈式存儲結(jié)構(gòu)
線性表是最基本、最簡單、也是最常用的一種數(shù)據(jù)結(jié)構(gòu)。線性表(linear list)是數(shù)據(jù)結(jié)構(gòu)的一種,一個線性表是n個具有相同特性的數(shù)據(jù)元素的有限序列,這篇文章帶你學習下線性表的鏈式存儲結(jié)構(gòu)2021-11-11淺談Linux環(huán)境下并發(fā)編程中C語言fork()函數(shù)的使用
fork函數(shù)在Linux中可以創(chuàng)建子進程即一個新的進程,這里我們根據(jù)實例來淺談Linux環(huán)境下并發(fā)編程中C語言fork()函數(shù)的使用,需要的朋友可以參考下2016-06-06