C语言使用链表实现学生信息管理系统
本文实例为大家分享了C语言实现学生信息管理系统的具体代码,供大家参考,具体内容如下
代码实现的功能:
1.插入学生信息2.显示学生信息3.删除学生信息4.在指定位置插入学生信息5.查找学生信息
代码内容:
#include#include #include #defineMax_Student_Num10 #defineMax_Str_len20 typedefstructT_student{ intnumber; charname[Max_Student_Num]; charphone[Max_Student_Num]; }; typedefstructT_Node{ structT_students; structT_Node*next; }; charcommand_str[]={"\n1displayallmember;\n2insertmember;\n3delmember;\n4exit\nCommandselection:"}; structT_studentstudents[Max_Student_Num]; structT_Node*head=NULL; intmain(intargc,char*argv[]) { intcommand,i; structT_studentstudent; structT_Node*pStu=head; memset(&student,0,sizeof(student)); while(1){ printf("%s",command_str); scanf("%d",&command); switch(command) { case1: if(head==NULL){ printf("empty!!!!!!!!!!!!\n"); break; } if(head->next==head){ display_student(head); }else{ pStu=head->next; do { display_student(pStu); pStu=pStu->next; }while(pStu!=head->next); // } break; case2: printf("enternewstudentnumber:"); scanf("%d",&student.number); printf("enternewstudentname:"); scanf("%s",&student.name); if(strlen(student.name)>Max_Str_len) { printf("nameistoolong!!\n"); continue; } printf("enternewstudentphone:"); scanf("%s",&student.phone); if(strlen(student.phone)>Max_Str_len) { printf("phoneistoolong!!\n"); continue; } printf("\n"); if(student.number!=0) insert_student(student); break; case3: printf("Interdeletedstudentnumber:"); scanf("%d",&student.number); del_student(student); break; case4: return0; default: printf("errorcommand,tryagain\n"); break; } } } voiddisplay_student(structT_Node*pStu){ printf("number:%dname:%sphone:%s\n",pStu->s.number,pStu->s.name,pStu->s.phone); } voidinsert_student(structT_studentstudent){ structT_Node*pNode; structT_Node*pStu=NULL; intsize=sizeof(structT_Node); pStu=(structT_Node*)malloc(size); if(pStu==NULL){ return; } memcpy(&pStu->s,&student,sizeof(student)); if(head==NULL){ pStu->next=head; head=pStu; head->next=head; return; } pStu->next=head->next; head->next=pStu; } voiddel_student(structT_studentstudent){ structT_Node*pNode=NULL,*p=NULL; if(head->next==head&&head->s.number==student.number){ pNode=head; head=NULL; free(pNode); printf("success"); return; } for(pNode=head->next;pNode!=head;pNode=pNode->next){ if(pNode->next->s.number==student.number){ p=pNode->next->next; free(pNode->next); pNode->next=p; printf("Deletesuccess!\n"); return; } } printf("NotFound\n"); }
测试截图:
1.插入功能:
2.显示功能:
3.查询功能:
4.删除功能:
5.指定位置插入:
更多学习资料请关注专题《管理系统开发》。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。