家谱管理系统的源代码.doc
《家谱管理系统的源代码.doc》由会员分享,可在线阅读,更多相关《家谱管理系统的源代码.doc(43页珍藏版)》请在咨信网上搜索。
。 #include<iostream.h> #include<string.h> #include<fstream.h> #include<stdlib.h> struct per{ int data; char name[20]; char brith[20]; char marry; char address[20]; char live; char dietime[20]; char parent[20]; int generation; int child[10]; int numberchild; per(){ for(int i=0;i<20;i++) name[i]='\0'; for(i=0;i<20;i++) brith[i]='\0'; for(i=0;i<20;i++) address[i]='\0'; for(i=0;i<20;i++) dietime[i]='\0'; for(i=0;i<10;i++) child[i]=0; for(i=0;i<20;i++) parent[i]='\0'; live='\0'; marry='\0'; data=-10; generation=0; numberchild=0; } }; void setupinfo(per person[]); void display(per person[],int&); void displayhome(per person[],int&); void displayinfo(per person[],int&); void namesearch(per person[],int&); void birtfdaysearch(per person[],int&); void addchild(per person[],int&); void editmember(per person[],int&); void sortbirthday(per person[],int&); void main() { per person[36]; int count=0; fstream inputFile("person.txt",ios::in|ios::out|ios::binary); if(!inputFile) { cout<<"文件不存在!"<<endl; exit(0); } inputFile.read((char*)&person[count],sizeof(person[count]));//从文件中读取指定大小的字节函数read(),读取字节函数 while(!inputFile.eof()) //当文件没有读取完毕,进行循环 { if(person[count].name[0]!='\0')//当名字不为空时 { count++; //统计人数 inputFile.read((char*)(person+count),sizeof(*person)); } } inputFile.close();//关闭文件 if(count<1) //如果家谱图里面没人 { cout<<" 家谱不存在,请你建立一个家谱!!"<<endl; setupinfo(person); } display(person,count); } void setupinfo(per person[36]) //创建信息 { int i,j,k; fstream outputfile("person.txt",ios::in|ios::out|ios::binary|ios::app); //打开文件 for(i=0;i<5;i++) { cout<<" 姓名 : "; cin.getline(person[i].name,20); cout<<" 生日(日期样式为xxxx/xx/xx) : "; cin.getline(person[i].brith,20); cout<<" 婚否(输入Y或y或N或n) :"; cin>>person[i].marry; while(toupper(person[i].marry)!='Y'&&toupper(person[i].marry)!='N') { cout<<" 你输入错误,请你重新输入!!"<<endl; cout<<" 婚否(输入Y或y或N或n) :"; cin>>person[i].marry; } cin.ignore(); cout<<" 地址 : "; cin.getline(person[i].address,20); cout<<" 是否健在(输入Y或y或N或n) :"; cin>>person[i].live; //是否死亡 while(toupper(person[i].live)!='Y'&&toupper(person[i].live)!='N') { cout<<" 你输入错误,请你重新输入!!"<<endl; cout<<" 婚否(输入Y或y或N或n) :"; cin>>person[i].live; } cin.ignore(); if(toupper(person[i].live)=='N') { cout<<" 死亡日期(日期样式为xxxx/xx/xx) :"; cin.getline(person[i].dietime,20);// 输入死亡日期 } cout<<" 属于第几代 : "; cin>>person[i].generation; cin.ignore(); if(person[i].generation!=1) //不是第一代 { cout<<" 他(她)的父亲 : "; cin.getline(person[i].parent,20); //cin.getline是读取字符串函数 20是读取字符串的个数 } cout<<endl; } for(j=0;j<i;j++) { if(person[j].generation==1) person[j].data=-1; //**************************** } for(j=0;j<i;j++) { for(k=0;k<i;k++) { if(strcmp(person[j].parent,person[k].name)==0) //比较2个字符串是否相同,实质是找某个人的父亲 person[j].data=k; } } for(j=0;j<i;j++) { for(k=0;k<i;k++) { if(strcmp(person[j].parent,person[k].name)==0) { person[k].child[person[k].numberchild]=j; person[k].numberchild++; //找某个人的孩子 } } } for(j=0;j<i;j++) outputfile.write((char*)(person+j),sizeof(*person)); //写文件 outputfile.close(); //关闭文件夹 system("cls"); } void display(per person[36],int &n1) { int choice; while(1) //循环式一直进行的 { cout<<endl<<endl<<endl; cout<<"\t\t 家族关系查询系统"<<endl; cout<<"\t\t1. 显示家谱"<<endl; cout<<"\t\t2. 显示第n代人的所有信息"<<endl; cout<<"\t\t3. 按照姓名查询某成员的信息"<<endl; cout<<"\t\t4. 按照出生日期查询成员名单"<<endl; cout<<"\t\t5. 某成员添加孩子"<<endl; cout<<"\t\t6. 修改某成员信息"<<endl; cout<<"\t\t7. 按生日日期对家谱中的所有人进行排序"<<endl; cout<<"\t\t8. 退出系统"<<endl; cout<<"\t\t 输入选择:"<<endl; cout<<"\t\t 请输入1-8之间的数"<<endl; cin>>choice; while (choice!=1&&choice!=2&&choice!=3&&choice!=4&&choice!=5&&choice!=6&&choice!=7 &&choice!=8) { cout<<"you enter wrong!"<<endl; cout<<"please enter again!"<<endl; cin>>choice; } cin.ignore(1,'\n'); //跳过一个字符,含义是忽略一行 system("cls"); switch(choice) { case 1: displayhome(person,n1); break; case 2: displayinfo(person,n1); break; case 3: namesearch(person,n1); break; case 4: birtfdaysearch(person,n1); break; case 5: addchild(person,n1); break; case 6: editmember(person,n1); break; case 7: sortbirthday(person,n1); break; case 8: exit(0); } } } void displayhome(per person[36],int &n2) //调用函数的参数 传递的是一个参数地址 { int i,j,max; char again; cout<<endl<<endl; for(i=0;i<n2-1;i++) { max=person[i].generation; for(j=i+1;j<n2;j++) { if(person[i].generation<person[j].generation) max=person[j].generation; //找出最大的代数 } } for(i=1;i<=max;i++) { cout<<" 第"<<i<<"代的成员有 : "; for(j=0;j<n2;j++) { if(person[j].generation==i) cout<<person[j].name<<" "; //输出每一代的人 } cout<<endl; } cout<<endl<<endl; cout<<" 你是否想继续查看?如果继续请输入Y或y,否则输入N或n!"<<endl; cin>>again; if(toupper(again)=='Y') //就是判断输入得是否为y或Y { system("cls"); return; } if(toupper(again)=='N') exit(0); //终止程序的执行 } void displayinfo(per person[36],int &n2) //显示代数 { int i,gen,j=0; char again; cout<<endl<<endl; cout<<" 请你输入你要查询的代数 : "; cin>>gen; cout<<endl; //换行 for(i=0;i<n2;i++) { if(person[i].generation!=gen) j++; } if(j==n2) //判断是否找到 cout<<" 你要查的代数还没有!!!"<<endl<<endl; for(i=0;i<n2;i++) { if(person[i].generation==gen) { cout<<" 姓名 : "<<person[i].name<<endl <<" 出生日期 : "<<person[i].brith<<" 第几代 : "<<person[i].generation<<endl <<" 婚否 : "<<person[i].marry<<" 地址 :"<<person[i].address<<endl <<" 是否健在 : "<<person[i].live<<endl; if(person[i].live=='N'||person[i].live=='n') cout<<" 死亡日期 : "<<person[i].dietime<<endl; cout<<endl<<endl; } } cout<<" 你是否想继续查看?如果继续请输入Y或y,否则输入N或n!"<<endl; cin>>again; if(toupper(again)=='Y') { system("cls"); return; } if(toupper(again)=='N') exit(0); } void namesearch(per person[36],int &n2) { int i,j=0,k; char again,name[20]; cout<<endl<<endl; cout<<" 请你输入你想要查询的人的姓名 : "; cin.getline(name,20); for(i=0;i<n2;i++) { if(strcmp(person[i].name,name)!=0) j++; } cout<<endl<<endl; if(j==n2) cout<<" 你要查询的人没有!!!"<<endl<<endl; for(i=0;i<n2;i++) { if(strcmp(person[i].name,name)==0) { cout<<" 姓名 : "<<person[i].name<<endl <<" 出生日期 : "<<person[i].brith<<" 第几代 : "<<person[i].generation<<endl <<" 婚否 : "<<person[i].marry<<" 地址 :"<<person[i].address<<endl <<" 是否健在 : "<<person[i].live<<endl; if(person[i].live=='N'||person[i].live=='n') cout<<" 死亡日期 : "<<person[i].dietime<<endl; cout<<endl<<endl; if(person[i].generation==1) cout<<" 他是这个家的根,没有父亲!!!!"<<endl<<endl; else { cout<<" 他(她)父亲的信息 : "<<endl; cout<<" 姓名 : "<<person[person[i].data].name<<endl <<" 出生日期 : "<<person[person[i].data].brith <<" 第几代 : "<<person[person[i].data].generation<<endl <<" 婚否 : "<<person[person[i].data].marry <<" 地址 :"<<person[person[i].data].address<<endl <<" 是否健在 : "<<person[person[i].data].live<<endl; if(person[person[i].data].live=='N'||person[person[i].data].live=='n') cout<<" 死亡日期 : "<<person[person[i].data].dietime<<endl; cout<<endl<<endl; } if(person[i].numberchild==0) cout<<" 他没有孩子!!!"<<endl<<endl; else { cout<<" 他有"<<person[i].numberchild<<"个孩子,他们的信息 :"<<endl<<endl; for(k=0;k<person[i].numberchild;k++) { cout<<" 姓名 : "<<person[person[i].child[k]].name<<endl <<" 出生日期 : "<<person[person[i].child[k]].brith <<" 第几代 : "<<person[person[i].child[k]].generation<<endl <<" 婚否 : "<<person[person[i].child[k]].marry <<" 地址 :"<<person[person[i].child[k]].address<<endl <<" 是否健在 : "<<person[person[i].child[k]].live; if(person[person[i].child[k]].live=='N'||person[person[i].child[k]].live=='n') cout<<" 死亡日期 : "<<person[person[i].child[k]].dietime<<endl; cout<<endl<<endl; } } } } cout<<" 你是否想继续查看?如果继续请输入Y或y,否则输入N或n!"<<endl; cin>>again; if(toupper(again)=='Y') { system("cls"); return; } if(toupper(again)=='N') exit(0); } void birtfdaysearch(per person[36],int &n2) { char begbir[20],endbir[20],again; int i,flag=0; cout<<endl<<endl; cout<<" 请你输入两个时间,格式为****/**/**!"<<endl; cout<<" 起始时间是 : "; cin.getline(begbir,20); cout<<" 终止时间是 : "; cin.getline(endbir,20); cout<<endl<<endl; for(i=0;i<n2;i++) { if(strcmp(person[i].brith,begbir)>=0&&strcmp(person[i].brith,endbir)<=0) { cout<<" 姓名 : "<<person[i].name; cout<<" 生日 : "<<person[i].brith; flag=1; cout<<endl; } } cout<<endl<<endl; if(flag==0) cout<<" 在这段时间内没有人生日!!!"<<endl<<endl; cout<<" 你是否想继续查看?如果继续请输入Y或y,否则输入N或n!"<<endl; cin>>again; if(toupper(again)=='Y') { system("cls"); return; } if(toupper(again)=='N') exit(0); } void addchild(per person[36],int &n2) { int i; char again; fstream file("person.txt",ios::in|ios::out|ios::binary|ios::app); cout<<endl<<endl; cout<<" 请输入孩子的信息!!!"<<endl<<endl<<endl; cout<<" 姓名 : "; cin.getline(person[n2].name,20); cout<<" 生日(日期样式为xxxx/xx/xx) : "; cin.getline(person[n2].brith,20); cout<<" 婚否(输入Y或y或N或n) :"; cin>>person[n2].marry; while(toupper(person[n2].marry)!='Y'&&toupper(person[n2].marry)!='N') { cout<<" 你输入错误,请你重新输入!!"<<endl; cout<<" 婚否(输入Y或y或N或n) :"; cin>>person[n2].marry; } cin.ignore(); cout<<" 地址 : "; cin.getline(person[n2].address,20); cout<<" 是否健在(输入Y或y或N或n) :"; cin>>person[n2].live; while(toupper(person[n2].live)!='Y'&&toupper(person[n2].live)!='N') { cout<<" 你输入错误,请你重新输入!!"<<endl; cout<<" 婚否(输入Y或y或N或n) :"; cin>>person[n2].live; } cin.ignore(); if(toupper(person[n2].live)=='N') { cout<<" 死亡日期(日期样式为xxxx/xx/xx) :"; cin.getline(person[n2].dietime,20); } cout<<" 属于第几代 : "; cin>>person[n2].generation; cin.ignore(); if(person[n2].generation!=1) { cout<<" 他(她)的父亲 : "; cin.getline(person[n2].parent,20); } cout<<endl; for(i=0;i<n2;i++) { if(strcmp(person[n2].parent,person[i].name)==0) { person[n2].data=i; break; } } file.write((char*)&person[n2],sizeof(person[n2])); file.close(); file.open("person.txt",ios::in|ios::out|ios::binary); file.seekp(i*sizeof(per),ios::beg); person[i].child[person[i].numberchild]=n2; person[i].numberchild++; file.write((char*)&person[i],sizeof(per)); file.close(); n2++; cout<<" 你是否想继续查看?如果继续请输入Y或y,否则输入N或n!"<<endl; cin>>again; if(toupper(again)=='Y') { system("cls"); return; } if(toupper(again)=='N') exit(0); } void editmember(per person[36],int &n2) { int i,flag=0,choice; char name[20],again; fstream file("person.txt",ios::in|ios::out|ios::binary); cout<<endl<<endl; cout<<" 请你输入你想修改的成员的名字 : "; cin.getline(name,20); cout<<endl<<endl; for(i=0;i<n2;i++) { if(strcmp(person[i].name,name)==0) { flag=1; break; } } if(flag==0) cout<<" 家谱中没有这个人!!"<<endl<<endl<<endl; if(flag==1) { cout<<"\t\t请你选择你要修改的项!!"<<endl; cout<<"\t\t 1. 姓名"<<endl; cout<<"\t\t 2. 地址"<<endl; cout<<"\t\t 3. 婚否"<<endl; cout<<"\t\t 4. 生日"<<endl; cout<<"\t\t 5. 是否死亡"<<endl; cout<<"\t\t 6. 死亡日期"<<endl; cout<<"\t\t 请输入1-6之间的数"<<endl; cout<<"\t\t 输入选择 : "; cin>>choice; while (choice!=1&&choice!=2&&choice!=3&&choice!=4&&choice!=5&&choice!=6) { cout<<"you enter wrong!"<<endl; cout<<"please enter again!"<<endl; cin>>choice; } cin.ignore(1,'\n'); switch(choice) { case 1: cout<<endl<<" 请你输入新名字 : "; cin.getline(person[i].name,20); // file.seekp(i*sizeof(per),ios::beg); // file.write((char*)&person[i],sizeof(per)); break; case 2: cout<<endl<<" 请输入新的地址 : "; cin.getline(person[i].address,20); // file.seekp(i*sizeof(per),ios::beg); // file.write((char*)&person[i],sizeof(per)); break; case 3: cout<<endl<<" 请你输入新的是否结婚 : "; cin>>person[i].marry; // file.seekp(i*sizeof(per),ios::beg); // file.write((char*)&person[i],sizeof(per)); break; case 4: cout<<endl<<" 请你输入新的生日 : "; cin.getline(person[i].brith,20); // file.seekp(i*sizeof(per),ios::beg); // file.write((char*)&person[i],sizeof(per)); break; case 5: cout<<endl<<" 请你输入新的是否死亡 : "; cin>>person[i].live; // file.seekp(i*sizeof(per),ios::beg); // file.write((char*)&person[i],sizeof(per)); break; case 6: cout<<endl<<" 请你输入新的死亡日期 : "; cin.getline(person[i].dietime,20); // file.seekp(i*sizeof(per),ios::beg); // file.write((char*)&person[i],sizeof(per)); break; } for(int j=0;j<n2;j++) file.write((char*)&person[j],sizeof(per)); } cout<<endl<<endl; cout<<" 你是否想继续查看?如果继续请输入Y或y,否则输入N或n!"<<endl; cin>>again; if(toupper(again)=='Y') { system("cls"); return; } if(toupper(again)=='N') exit(0); } void sortbirthday(per person[36],int &n2) { per person1; int i,j; char again; cout<<endl<<endl; for(i=0;i<n2-1;i++) for(j=i+1;j<n2;j++) { if(strcmp(person[i].brith,person[j].brith)>=0) { person1=person[i]; person[i]=person[j]; person[j]=person1; } } for(i=0;i<n2;i++) cout<<" 姓名 : "<<person[i].name<<" 生日 : "<<person[i].brith<<endl; cout<<endl<<endl; cout<<" 你是否想继续查看?如果继续请输入Y或y,否则输入N或n!"<<endl; cin>>again; if(toupper(again)=='Y') { system("cls"); return; } if(toupper(again)=='N') exit(0); } THANKS !!! 致力为企业和个人提供合同协议,策划案计划书,学习课件等等 打造全网一站式需求 欢迎您的下载,资料仅供参考 -可编辑修改-- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 家谱 管理 系统 源代码
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【a199****6536】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【a199****6536】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【a199****6536】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【a199****6536】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文