Inheritance: 課題
人の血液型は2つの異なる形態の遺伝子(対立遺伝子)によって決まるが、可能性のある3つの対立遺伝子はA、B、Oであり、それぞれの人は2つ持つ。子供の両親はそれぞれ2つの血液型対立遺伝子の1つを子供にランダムに渡すから、考えられる血液型の組み合わせは、OO、OA、OB、AO、AA、AB、BO、BA、BBとなる。
たとえば、片方の親の血液型がAOで、もう一方の親の血液型がBBである場合、それぞれの親からどの対立遺伝子を受け取るかによって、子の血液型はABまたはOBになります。同様に、片方の親の血液型がAOで、もう一方がOBである場合、子の血液型はAO、OB、AB、およびOOになります。
今回の課題は、これをシミュレーションするというもの。
https://cs50.harvard.edu/x/2021/labs/5/
Filter: 回答例
// Simulate genetic inheritance of blood type
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
// Each person has two parents and two alleles
typedef struct person
{
struct person *parents[2];
char alleles[2];
}
person;
const int GENERATIONS = 3;
const int INDENT_LENGTH = 4;
person *create_family(int generations);
void print_family(person *p, int generation);
void free_family(person *p);
char random_allele();
int main(void)
{
// Seed random number generator
srand(time(0));
// Create a new family with three generations
person *p = create_family(GENERATIONS);
// Print family tree of blood types
print_family(p, 0);
// Free memory
free_family(p);
}
// Create a new individual with `generations`
person *create_family(int generations)
{
// TODO: Allocate memory for new person
person *n = malloc(sizeof(person));
if (n == NULL)
{
return NULL;
}
// Generation with parent data
if (generations > 1)
{
// TODO: Recursively create blood type histories for parents
n->parents[0] = create_family(generations - 1);
n->parents[1] = create_family(generations - 1);
// TODO: Randomly assign child alleles based on parents
n->alleles[0] = n->parents[0]->alleles[rand() % 2];
n->alleles[1] = n->parents[1]->alleles[rand() % 2];
}
// Generation without parent data
else
{
// TODO: Set parent pointers to NULL
n->parents[0] = NULL;
n->parents[1] = NULL;
// TODO: Randomly assign alleles
n->alleles[0] = random_allele();
n->alleles[1] = random_allele();
}
// TODO: Return newly created person
return n;
}
// Free `p` and all ancestors of `p`.
void free_family(person *p)
{
// TODO: Handle base case
if (p == NULL)
{
return;
}
// TODO: Free parents
free_family(p->parents[0]);
free_family(p->parents[1]);
// TODO: Free child
free(p);
}
// Print each family member and their alleles.
void print_family(person *p, int generation)
{
// Handle base case
if (p == NULL)
{
return;
}
// Print indentation
for (int i = 0; i < generation * INDENT_LENGTH; i++)
{
printf(" ");
}
// Print person
printf("Generation %i, blood type %c%c\n", generation, p->alleles[0], p->alleles[1]);
print_family(p->parents[0], generation + 1);
print_family(p->parents[1], generation + 1);
}
// Randomly chooses a blood type allele.
char random_allele()
{
int r = rand() % 3;
if (r == 0)
{
return 'A';
}
else if (r == 1)
{
return 'B';
}
else
{
return 'O';
}
}
未希 諒
香港在住の34歳サラリーマン。戦略家、写真家、旅人、サウナー。 2025年までに季節を選びながら世界中を飛び回る仕事をするために準備中。その道中で発見した気づきや気になる話題を中心に発信しています。2010年より旅をスタートし通算500箇所の宿に宿泊。年間の3分の1をホテルで暮らす。
Related posts
About media
Ramps Blog は、ノマドによるノマドのためのブログです。日本、香港、シンガポール、タイ、台湾のノマド生活を通じて見えた景色、特に食、カルチャー、テクノロジー、ビジネス、アート、デザインなどについて発信しています。
Recent Posts
Twitter feed is not available at the moment.