gpt4 book ai didi

c - 我在 C 中传递地址时无法取平均值

转载 作者:太空宇宙 更新时间:2023-11-04 01:11:30 25 4
gpt4 key购买 nike

下面是我的代码的主要部分。我正在使用一些外部文件。在函数 3.6 中,我无法计算我的(在本例中)总工资率 (pr) 和我的总员工数 (empCount) 的平均值。我在这里缺少什么吗?当我编译它时,我收到一条错误消息,提示操作数无效。当我修复这些问题时,我的输出为 0。我对编程很陌生,所以在我尝试回答任何问题时请多多包涵。我遇到问题的函数是代码中的倒数第二个函数(3.6 AddDetailToAccumulator)。非常感谢。

#include <stdio.h>
#include <stdlib.h>
#include "EmployeeRecord.h"
#include "CalcTaxes.o"
#define ADDR(var) &var
#define REPORTCOLUMNHEADINGS1 "Employee Pay Reg Hrs Gross Fed SSI Net\n"
#define REPORTCOLUMNHEADINGS2 "Name Rate OVT Hrs Pay State Defr Pay\n"
#define BARS "======== ===== ======= ======= ====== ====== =======\n\n"
#define REPORTCOLUMN1 "%s, %s\t%8.2f%8.2f%10.2f%8.2f%8.2f%9.2f\n"
#define REPORTCOLUMN2 "%32.2f%18.2f%8.2f\n\n"

void PrintReportHeadings(FILE * ReportFile); //3.1
void InputEmployeeData(int count,char * lastname,char * firstname,float * hours,float * payrate,float * defr); //3.3
float CalculateGross(float hours, float payrate, float reghours, float ovthours); //3.4 CalculateGross
extern void CalculateTaxes(float gross, float defr, float *ft, float *st, float *ssit); //3.5 CalculateTaxes
void AddDetailToAccumulator(int count,int *empCount,float *pr,float *payrate,float *reg,float *reghours,float *ovt,float *ovthours,float *gp,
float *gross,float *fedt,float *ft,float *stt,float *st,float *sst,float *ssit,float *def,
float *defr,float *np,float *net,float *avgpr);//3.6 AddDetailToAccumulator
void PrintSummaryReport(float pr,float reg,float ovt,float gp,float fedt,float stt,float sst,float def,float np,float *avgpr,float avgreg,float avgovt,
float avggp,float avgfedt,float avgstt,float avgsst,float avgdef,float avgnp,FILE * ReportFile); //3.7

int main()
{
EmployeeRecord r; // Call Employee Record Definitions
float reghours,ovthours;
float ft,st,ssit;
float pr,reg,ovt,gp,fedt,stt,sst,def,np;
float avgpr,avgreg,avgovt,avggp,avgfedt,avgstt,avgsst,avgdef,avgnp;
char answer;
int empCount,count;
FILE * ReportFile;

PrintReportHeadings(ReportFile); //Call 3.1 PrintReportHeadings

empCount = 0;// count initializations
pr = reg = ovt = gp = fedt = stt = def = sst = np = 0;
avgpr = avgreg = avgovt = avggp = avgfedt = avgstt = avgsst = avgdef = avgnp = 0;
do
{
InputEmployeeData(count,r.firstname,r.lastname,&r.payrate,&r.defr,&r.hours);//Call 3.3 InputEmployeeData
if (r.hours > 40)//Check for Overtime Hours
{
reghours = 40;
ovthours = r.hours - 40;
}
else {
reghours = r.hours;
ovthours = 0;
}
r.gross = CalculateGross(r.hours,r.payrate,reghours,ovthours); //3.4 CalculateGross
CalculateTaxes(r.gross,r.defr,&ft,&st,&ssit);//Call 3.5 CalculateTaxes

r.net = r.gross - ft - st - ssit;// Calculate Net Earnings

printf(REPORTCOLUMNHEADINGS1);
printf(REPORTCOLUMNHEADINGS2);
printf(BARS);
printf(REPORTCOLUMN1,r.lastname,r.firstname,r.payrate,reghours,r.gross,ft,ssit,r.net);
printf(REPORTCOLUMN2,ovthours,st,r.defr);
ReportFile = fopen("report.txt", "a");
fprintf(ReportFile,REPORTCOLUMN1,r.lastname,r.firstname,r.payrate,reghours,r.gross,ft,ssit,r.net);
fprintf(ReportFile,REPORTCOLUMN2,ovthours,st,r.defr);
fclose(ReportFile);

AddDetailToAccumulator(count,&empCount,&pr,&r.payrate,&reg,&reghours,&ovt,&ovthours,&gp,&r.gross,&fedt,&ft,&stt,&st,&sst,&ssit,
&def,&r.defr,&np,&r.net,&avgpr);//3.6


while (getchar() != '\n');
printf(" Repeat (Y/N)? : ");
scanf("%c",ADDR(answer));
} while (answer == 'Y' || answer == 'y');
printf("\n"); // print one line for spacing
printf("\nTotals %17.2f%8.2f%10.2f%8.2f%8.2f%9.2f\n",pr,reg,gp,fedt,sst,np);
printf("%32.2f%18.2f%8.2f\n",ovt,stt,def);

printf("%d",count);

printf("\nAverages %15.2f%8.2f%10.2f%8.2f%8.2f%9.2f\n",avgpr,avgreg,avggp,avgfedt,avgstt,avgnp);
printf("%32.2f%18.2f%8.2f\n",avgovt,avgsst,avgdef);

PrintSummaryReport(pr,reg,ovt,gp,fedt,stt,sst,def,np,&avgpr,avgreg,avgovt,
avggp,avgfedt,avgstt,avgsst,avgdef,avgnp,ReportFile); //Call 3.7 PrintSummaryReport

fflush(stdin);
getchar();
return 0;
}

void PrintReportHeadings(FILE * ReportFile) //3.1
{
ReportFile = fopen("report.txt", "w");
fprintf(ReportFile,REPORTCOLUMNHEADINGS1);
fprintf(ReportFile,REPORTCOLUMNHEADINGS2);
fprintf(ReportFile,BARS);
fclose(ReportFile);
}

void InputEmployeeData(int count,char * lastname,char * firstname, float * payrate, float * defr, float * hours) //3.3
{
printf("Enter employee's name: "); // input section
scanf("%s%s",firstname,lastname);
printf("Enter hourly pay rate: ");
scanf("%f",payrate);
printf("Enter deferred amount: ");
scanf("%f",defr);
printf("Enter hours worked this pay period: ");
scanf("%f",hours);
}

float CalculateGross(float hours, float payrate, float reghours, float ovthours) // 3.4
{
return (reghours * payrate)+(ovthours * payrate * 1.5);
}

void AddDetailToAccumulator(int *empCount,float *pr,float *payrate,float *reg,float *reghours,float *ovt,float *ovthours,float *gp,
float *gross,float *fedt,float *ft,float *stt,float *st,float *sst,float *ssit,float *def,
float *defr,float *np,float *net,float *avgpr)//3.6
{
empCount = empCount +1;
*pr = *pr + *payrate;
*reg = *reg + *reghours;
*ovt = *ovt + *ovthours;
*gp = *gp + *gross;
*fedt = *fedt + *ft;
*stt = *stt + *st;
*sst = *sst + *ssit;
*def = *def + *defr;
*np = *np + *net;

*avgpr = *pr / empCount;
}


void PrintSummaryReport(float pr,float reg,float ovt,float gp,float fedt,float stt,float sst,float def,float np,float * avgpr,float avgreg,float avgovt,
float avggp,float avgfedt,float avgstt,float avgsst,float avgdef,float avgnp,FILE * ReportFile) //3.7
{
ReportFile = fopen("report.txt", "a");
fprintf(ReportFile,"\nTotals %17.2f%8.2f%10.2f%8.2f%8.2f%9.2f\n",pr,reg,gp,fedt,sst,np);
fprintf(ReportFile,"%32.2f%18.2f%8.2f\n",ovt,stt,def);
fprintf(ReportFile,"\nAverages %15.2f%8.2f%10.2f%8.2f%8.2f%9.2f\n",&avgpr,avgreg,avggp,avgfedt,avgsst,avgnp);
fprintf(ReportFile,"%32.2f%18.2f%8.2f\n",avgovt,avgstt,avgdef);
fclose(ReportFile);
}

最佳答案

您在此处的 empcount 变量上遗漏了 *:

empCount = empCount +1;

在这里

*avgpr = *pr / empCount ;

关于c - 我在 C 中传递地址时无法取平均值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11732798/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com