0

我是 C 新手,我不知道为什么我的两个扫描功能都会出现类型冲突的错误。非常感谢改进我的代码的解决方案或任何建议。分配方向如下所示。

您的程序应读取包含器官等待列表的文件的信息,以及收到的捐赠器官序列。对于收到的每个器官,您的程序应打印出人员的姓名和他们收到的器官。器官应该交给在候补名单上时间最长的人,谁是器官的匹配者。出于此分配的目的,当供体器官相同并且供体的血型与受体相同时,就会发生匹配。一旦找到一个器官匹配,它们就不应再次匹配。

输入文件格式

输入文件的第一行将包含一个正整数 n (n ≤ 120000),表示等待名单上的器官数量。接下来的 n 行将包含有关每个器官的信息。这些行中的每一行都将包含人的姓名、他们需要更换的器官、他们的血型、他们被添加到器官数据库的日期以及他们被添加到器官数据库的时间。这些项目中的每一个都将由一个空格分隔。所有名称将仅由字母和下划线组成,所有器官名称将由小写字母组成,所有血型将是前面提到的 8 个字符串之一,所有日期将采用 m/d/y 格式,其中 m, d和 +y 表示将患者添加到器官捐赠列表(针对该特定器官)的数字月日和年份。最后,时间的格式为 hr:min,其中 hr(0 ≤ hr ≤ 23) 和 min(0 ≤ min ≤ 59) 表示将患者添加到器官捐献列表的时间的数字小时和分钟。您可以保证在同一日期和时间没有将两个器官添加到列表中,并且任何名称或器官名称都不会包含超过 19 个字符。

输入文件的下一行(第 n+2 行)将包含一个正整数 k (k ≤ 1000),表示在某个固定时间段内收到的器官数量。以下 k 行将包含有关收到的器官的信息,按收到的顺序排列。这些行中的每一行都包含两个由空格分隔的字符串:器官名称和供体的血型。这些都将遵守前面给出的规范。

输出规格

为收到的每个器官输出一行。如果数据库中存在尚未收到器官的匹配接受者,请打印出接受者的姓名,然后是他们收到的器官。如果数据库中不存在匹配项,请在一行中打印以下内容。

No match found

样品输出:

Adam_Smith kidney
Jessica_Arte liver
Shelly_Zenith liver
No match found
No match found
John_Lynch kidney

样品输入:

10
John_Lynch kidney A- 12/13/2007 14:43
Beth_Silva lung O+ 1/23/2009 13:10
Adam_Smith kidney A- 12/13/2007 9:59
Jenn_Gray liver AB+ 9/9/1999 1:23
Sylvia_Maria lung O+ 1/24/2009 0:09
Sean_Stark heart AB- 8/23/2000 9:13
Shelly_Zenith liver AB- 9/10/1999 1:13
Jessica_Arte liver AB+ 8/31/1999 23:38
Bill_Muse heart O+ 3/23/2013 3:12
Samantha_Bogedon intestine B- 6/30/2012 17:08
6
kidney A-
liver AB+
liver AB-
heart O-
intestine A+
kidney A-

代码:

#include <stdio.h>
#include <stdlib.h>

#define SIZE 20
#define BLOODTYPESIZE 4

//Structure to store month day and year
typedef struct {
    int month;
    int day;
    int year;
} dateT;
// Structure to stores hour and minute
typedef struct {
    int hour;
    int minute;
} timeT;
// structure to store name organname bloodtype dateadded time added and whether or not it was received
typedef struct {
    char name[SIZE];
    char organname[SIZE];
    char bloodtype[BLOODTYPESIZE];
    dateT dateAdded;
    timeT timeAdded;
    int received;
} organT;

int main(){
    //Declare variables
    int numberOfOrgans,x,numberOfDonors,y,match,possible;
// Create pointer to structure
organT* organ;
scanf("%d",&numberOfOrgans);
organ = (organT *)malloc(numberOfOrgans*sizeof(organT));
scanOrgans(numberOfOrgans,organ);
scanf("%d",&numberOfDonors);
organT* donors;
donors = (organT *)malloc(numberOfDonors*sizeof(organT));
scanDonors(numberOfDonors, donors);
for(y=0;y<numberOfDonors;y++){
    match=-1;
    possible=-1;
    for(x=0;x<numberOfOrgans;x++){
        if((strcmp(organ[x].organname, donors[y].organname)==0) && (strcmp(organ[x].bloodtype, donors[y].bloodtype)==0) && (organ[x].received!=1)){
           match++;
            if (match>0)
                possible=organCompare(organ, x, possible);
            else if (match==0)
                possible=x;

            }
        else continue;
    }
    if (possible>-1){
        organ[possible].received=1;
        printf("%s %s\n",organ[possible].name, organ[possible].organname);
    }
    else
        printf("No match found\n");
        free(organ);
        free(donors);
    }
}
void scanOrgans(int x,organT* organ){

    int i;
    char temp[256];

    for(i=0;i<x;i++){

        scanf("%s",&organ[i].name);
        scanf("%s",&organ[i].organname);
        scanf("%s",&organ[i].bloodtype);
        scanf("%s",&temp);
        sscanf(temp,"%d/%d/%d",&organ[i].dateAdded.month,&organ[i].dateAdded.day,&organ[i].dateAdded.year);
        scanf("%s",&temp);
        sscanf(temp,"%d:%d",&organ[i].timeAdded.hour,&organ[i].timeAdded.minute);
   }
}
void scanDonors(int x, organT* donors ){
    int i;
    for(i=0;i<x;i++){
    scanf("%s%s", &donors[i].organname, &donors[i].bloodtype);
    }
}

int organCompare(organT* organ, int x, int y){
    if (organ[x].dateAdded.year<organ[y].dateAdded.year)
        return x;
    else if(organ[x].dateAdded.year==organ[y].dateAdded.year){
        if (organ[x].dateAdded.month<organ[y].dateAdded.month)
            return x;
        else if(organ[x].dateAdded.month==organ[y].dateAdded.month){
            if (organ[x].dateAdded.day<organ[y].dateAdded.day)
            return x;
            else if (organ[x].dateAdded.day==organ[y].dateAdded.day){
                if (organ[x].timeAdded.hour<organ[y].timeAdded.hour)
                return x;
                else if (organ[x].timeAdded.hour==organ[y].timeAdded.hour){
                    if (organ[x].timeAdded.minute<organ[y].timeAdded.minute)
                    return x;
                    else return y;
                    }
                else return y;
            }
            else return y;

        }
        else return y;
        }
    else return y;

    }
4

4 回答 4

2

这不是您的问题,但请避免比较器中的结构。试试这个:

int organCompare(organT* organ, int x, int y)
{
    if (organ[x].dateAdded.year < organ[y].dateAdded.year)
        return x;
    else if (organ[x].dateAdded.year > organ[y].dateAdded.year)
        return y;
    else if (organ[x].dateAdded.month < organ[y].dateAdded.month)
        return x;
    else if (organ[x].dateAdded.month < organ[y].dateAdded.month)
        return y;
    else if (organ[x].dateAdded.day < organ[y].dateAdded.day)
        return x;
    else if (organ[x].dateAdded.day > organ[y].dateAdded.day)
        return y;
    else if (organ[x].timeAdded.hour < organ[y].timeAdded.hour)
        return x;
    else if (organ[x].timeAdded.hour > organ[y].timeAdded.hour)
        return y;
    else if (organ[x].timeAdded.minute < organ[y].timeAdded.minute)
        return x;
    else
        return y;
}
于 2013-09-09T21:26:51.073 回答
2

在之前添加这三行int main()

 #include <string.h>
 void scanOrgans(int x, organT* organ);  
 void scanDonors(int x, organT* donors );
 int organCompare(organT* organ, int x, int y);
于 2013-09-09T21:18:07.273 回答
2

scanf与 a 一起使用时,char *您通常不需要&,因为您已经有一个指针。所以改变:

    scanf("%s",&organ[i].name);
    scanf("%s",&organ[i].organname);
    scanf("%s",&organ[i].bloodtype);

至:

    scanf("%s",organ[i].name);
    scanf("%s",organ[i].organname);
    scanf("%s",organ[i].bloodtype);

此外,不是这样的错误,但在 C 中你不应该转换 malloc 的结果,所以改变例如

donors = (organT *)malloc(numberOfDonors*sizeof(organT));

至:

donors = malloc(numberOfDonors*sizeof(organT));
于 2013-09-09T21:20:06.713 回答
1

编译器会抱怨,因为您正在使用未通过函数原型明确定义的函数。我在工作中留下了我的 C 参考,所以我找不到确切的段落,但编译器会猜测函数原型,这会导致您看到的“冲突类型”警告或错误。int从内存中,如果您没有指定任何内容,C 会假定函数返回 an 。

这是我最好的猜测。如果大卫施瓦茨的修复工作有效,我会非常确定这是原因。

于 2013-09-09T21:37:12.783 回答