036.模拟社会关系

简介: 036.模拟社会关系
#include <stdio.h>
#define CHILDREN 5
struct person{
  char *name;/*名字符串指针*/
  char sex;/*性别:男用字符'M';女用字符'F'*/
  struct person *father;/*指向父亲*/
  struct person *mother;/*指向母亲*/
  struct person *mate;/*指向配偶*/
  struct person *children[CHILDREN];/*指向子女*/
};
/* [函数]newperson增加新人 */
struct person *newperson(char *name,char sex)
{
  struct person *p;
  int index;
  p=(struct person *)malloc(sizeof(struct person));
  p->name=(char *)malloc(strlen(name)+1);
  strcpy(p->name,name);
  p->sex=sex;
  p->father=NULL;
  p->mother=NULL;
  p->mate=NULL;
  for(index=0;index<CHILDREN;index++)
    p->children[index]=NULL;
  return p;
}
/* [函数]father_child建立父-子关系 */
father_child(struct person *father,struct person *child)
{
  int index;
  for(index=0;index<CHILDREN-1;index++)/*寻找一个空缺的子女指针*/
    if(father->children[index]==NULL)/*若没有空缺,则填在最后*/
      break;
  father->children[index]=child;/*建立父-子关系*/
  child->father=father;
}
/* [函数]mother_child建立母-子关系 */
mother_child(struct person *mother,struct person *child)
{
  int index;
  for(index=0;index<CHILDREN-1;index++)/*寻找一个空缺的子女指针*/
    if(mother->children[index]==NULL)/*若没有空缺,则填在最后*/
      break;
  mother->children[index]=child;/*建立母-子关系*/
}
/* [函数]mate 建立配偶关系 */
mate(struct person *h,struct person *w)
{
  h->mate=w;/*建立配偶关系*/
  w->mate=h;
}
/* [函数]brotherinlow 检查两人是否是堂兄妹 */
int brothersinlaw(struct person *p1,struct person *p2)
{
  struct person *f1,*f2;
  if(p1==NULL||p2==NULL||p1==p2) return 0;
  if(p1->sex==p2->sex) return 0;/*不可能是堂兄妹*/
  f1=p1->father;
  f2=p2->father;
  if(f1!=NULL&&f1==f2) return 0;/*是兄妹,不是堂兄妹*/
  while(f1!=NULL&&f2!=NULL&&f1!=f2)/*考虑远房情况*/
  {
    f1=f1->father;
    f2=f2->father;
    if(f1!=NULL&&f2!=NULL&&f1==f2) return 1;
  }
  return 0;
}
/* 函数print_relate用于输出人物p的姓名,性别和各种关系 */
void print_relate(struct person *p)
{
  int index,i;
  if(p->name==NULL)
    return;
  if(p->sex=='M')
    printf(" %s is male.",p->name);
  else
    printf(" %s is female.",p->name);
  if(p->father!=NULL)
    printf(" %s's father is %s.",p->name,p->father->name);
  if(p->mother!=NULL)
    printf(" %s's mother is %s.",p->name,p->mother->name);
  printf("\n");
  if(p->mate!=NULL)
    if(p->sex=='M')
      printf(" His wife is %s.",p->mate->name);
    else
      printf(" Her husband is %s.",p->mate->name);
  if(p->children!=NULL)
  { for(index=0;index<CHILDREN-1;index++)/*寻找一个空缺的子女指针*/
    if(p->children[index]==NULL)/*若没有空缺,index为子女个数 */
      break;
    if(index>0)
      printf(" Children are:");
    for(i=0;i<index;i++)
      printf(" %s",p->children[i]->name);
  }
  printf("\n");
}
main()
{
  char *name[8]={"John","Kate","Maggie","Herry","Jason","Peter","Marry","Jenny"};
  char male='M',female='F';
  struct person *pGrandfather,*pFather1,*pFather2,*pMother1,*pMother2,*pSon,*pDaughter,*pCousin;
  clrscr();
  pGrandfather = newperson(name[0],male);
  pFather1 = newperson(name[3],male);
  pFather2 = newperson(name[4],male);
  pMother1 = newperson(name[1],female);
  pMother2 = newperson(name[2],female);
  pSon = newperson(name[5],male);
  pDaughter = newperson(name[6],female);
  pCousin = newperson(name[7],female);
  father_child(pGrandfather,pFather1);
  father_child(pGrandfather,pFather2);
  father_child(pFather1,pSon);
  father_child(pFather1,pDaughter);
  father_child(pFather2,pCousin);
  mate(pFather1,pMother1);
  mate(pFather2,pMother2);
  mother_child(pMother1,pSon);
  mother_child(pMother1,pDaughter);
  mother_child(pMother2,pCousin);
  /* 输出各种关系 */
  print_relate(pGrandfather);
  print_relate(pFather1);
  print_relate(pFather2);
  print_relate(pMother1);
  print_relate(pMother2);
  print_relate(pSon);
  print_relate(pDaughter);
  print_relate(pCousin);
  if(!brothersinlaw(pDaughter,pCousin))
    printf("%s and %s are not brothers (sisters) in law.\n",pDaughter->name,pCousin->name);
  else
    printf("%s and %s are brothers (sisters) in law.\n",pDaughter->name,pCousin->name);
  if(!brothersinlaw(pSon,pCousin))
    printf("%s and %s are not brothers (sisters) in law.\n",pSon->name,pCousin->name);
  else
    printf("%s and %s are brothers (sisters) in law.\n",pSon->name,pCousin->name);
  if(!brothersinlaw(pSon,pDaughter))
    printf("%s and %s are not brothers (sisters) in law.\n",pSon->name,pDaughter->name);
  else
    printf("%s and %s are brothers (sisters) in law.\n",pSon->name,pDaughter->name);
  puts("\n Press any key to quit...");
  getch();
}
相关文章
|
8月前
函数的模拟实现
函数的模拟实现
51 0
|
8月前
模拟队列训练
模拟队列训练
42 0
|
21天前
|
算法
【算法】模拟
替换所有问号,提莫攻击,z字形变换,外观数列,数青蛙
|
2月前
|
前端开发 JavaScript
模拟 new 的实现
模拟 `new` 实现是指在 JavaScript 中,通过自定义函数来模拟内置的 `new` 操作符的行为,以便更好地理解其工作原理和对象构造过程。这种方式通常涉及创建一个新对象、绑定原型链、执行构造函数等步骤。
|
5月前
|
XML 传感器 算法
SFNC —— 模拟控制(五)
SFNC —— 模拟控制(五)
50 3
|
8月前
|
C语言
深入理解并模拟实现函数
深入理解并模拟实现函数
|
8月前
|
图形学 Python
物理光学:光的探索与编程模拟
物理光学:光的探索与编程模拟
77 0
|
8月前
函数的模拟实现1
函数的模拟实现1
63 0
|
Python
抽卡程序模拟
抽卡程序模拟
150 0
|
SQL 监控 前端开发
模拟数据在实际场景中的应用
模拟数据在实际场景中的应用
183 0
模拟数据在实际场景中的应用

热门文章

最新文章