VC驿站

 找回密码
 加入驿站

QQ登录

只需一步,快速开始

搜索
查看: 205|回复: 1

家谱管理

[复制链接]
58_avatar_middle
最佳答案
0 
在线会员 发表于 2021-12-12 13:10:10 | 显示全部楼层 |阅读模式
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include"home.h"
void createtree(treeNode* p)
{
homeList fam;
int i;
printf("请输入家庭成员的基础信息\n");
printf("姓名:");
scanf("%s",fam.name);
printf("\n");
printf("性别:");
scanf("%s",&(fam.sex));
printf("\n");
printf("配偶:");
scanf("%s",fam.spouse);
printf("\n");
printf("-----------------------\n");//输入成员信息
p = (treeNode*)malloc(sizeof(treeNode));
p->firstchild = NULL;
p->nextsibling = NULL;              //分配空间
if( !p )
return ;
memcpy(&(p->data),&fam,sizeof(homeList));

do{
printf("%s是否有孩子\n",fam.name);
printf("是:1,否:0\n");
scanf("%d",&i);
switch( i )
{
case 0:break;
case 1:createtree(p->firstchild);break;
default:printf("输入错误,请重新输入");
}
}while(i != 0 && i != 1);       //输入孩子节点

do{
printf("%s是否有未存入的兄弟\n",fam.name);
printf("是:1,否:0\n");
scanf("%d",&i);
switch(i)
{
case 0:break;
case 1:createtree(p->nextsibling);break;
default:printf("输入错误,请重新输入");
}
}while(i != 0 && i != 1);      //输入兄弟节点

}


void Locatetree(treeNode*p,char nam[20])//查找节点
{
homeList fam;
memcpy(&(fam),&(p->data),sizeof(homeList));
printf("%s",fam.name);

if  (p!=NULL)
{

if(strcmp(p->data.name , nam) == 0)
{
printf("查找到的数据为:");
printf("姓名:%s",fam.name);
printf("性别:%c",fam.sex);
printf("配偶:%s",fam.spouse);     //输出查找到的节点
return ;
}

Locatetree(p->firstchild,nam);
if(p->firstchild != NULL)
{
p = p->firstchild;
return ;
}

Locatetree(p->nextsibling,nam);
if(p->nextsibling != NULL)
{
p = p->nextsibling;
return;
}
printf("未找到该成员");
}
}


void Addtree(treeNode* p){//加入新节点
treeNode* temp = p;
char nam[20];
printf("请输入需要添加的成员父母的姓名:");
scanf("%s",nam);
printf("\n");
Locatetree(temp,nam);
treeNode*a = ( treeNode* )malloc(sizeof(treeNode));
homeList fam;
printf("请输入家庭成员的基础信息\n");
printf("姓名:");
scanf("%s",fam.name);
printf("\n");
printf("性别:") ;
scanf("%s",&(fam.sex));
printf("\n");
printf("配偶:");
scanf("%s",fam.spouse);
printf("\n");
printf("-----------------------\n");
memcpy(&(a->data),&fam,sizeof(homeList));
a->firstchild = NULL ;
a->nextsibling = NULL ;
if(temp->firstchild!=NULL)
temp->firstchild = a;
else
temp = temp->firstchild;
while( temp )
{
temp = temp->nextsibling;
}
temp->nextsibling = a;
}





他显示c:\users\lenovo\desktop\test\family1\family1\familytree.c(5): error C2143: 语法错误 : 缺少“)”(在“*”的前面)
1>c:\users\lenovo\desktop\test\family1\family1\familytree.c(5): error C2143: 语法错误 : 缺少“{”(在“*”的前面)
1>c:\users\lenovo\desktop\test\family1\family1\familytree.c(5): error C2059: 语法错误:“)”
1>c:\users\lenovo\desktop\test\family1\family1\familytree.c(6): error C2054: 在“p”之后应输入“(”




上一篇:为什么我写的归并算法这么慢,帮看看问题所在
下一篇:html转图片
01_avatar_middle
最佳答案
0 
在线会员 发表于 2021-12-22 23:23:33 | 显示全部楼层
没人理你啊?我顶一下你,希望你的问题能得到解决。
您需要登录后才可以回帖 登录 | 加入驿站 qq_login

本版积分规则

×【发帖 友情提示】
1、请回复有意义的内容,请勿恶意灌水;
2、纯数字、字母、表情等无意义的内容系统将自动删除;
3、若正常回复后帖子被自动删除,为系统误删的情况,请重新回复其他正常内容或等待管理员审核通过后会自动发布;
4、感谢您对VC驿站一如既往的支持,谢谢合作!

关闭

站长提醒上一条 /2 下一条

QQ|小黑屋|手机版|VC驿站 ( 辽ICP备09019393号-4 )|网站地图wx_jqr

GMT+8, 2022-1-21 10:22

Powered by CcTry.CoM

© 2009-2021 cctry.com

快速回复 返回顶部 返回列表