给定N个职员的信息,包括姓名、基本工资、浮动工资和支出,要求编写程序顺序输出每位职员的姓名和实发工资(实发工资=基本工资+浮动工资-支出)。
输入格式:
输入在一行中给出正整数N。随后N行,每行给出一位职员的信息,格式为“姓名 基本工资 浮动工资 支出”,中间以空格分隔。其中“姓名”为长度小于10的不包含空白字符的非空字符串,其他输入、输出保证在单精度范围内。
输出格式:
按照输入顺序,每行输出一位职员的姓名和实发工资,间隔一个空格,工资保留2位小数。
输入样例:
3
zhao 240 400 75
qian 360 120 50
zhou 560 150 80
输出样例:
zhao 565.00
qian 430.00
zhou 630.00
分析:
- 首先定义了一个名为
t
的结构体,该结构体包含一个字符数组name
(用于存储人的名字)、三个浮点数salary1
、salary2
和pay
(分别代表一个人的两个工资和一个总工资)。 - 之后,代码读取一个整数
n
,表示要处理的人数。 - 定义了两个数组:一个名为
people
的结构体数组,用于存储每个员工的信息;一个名为fee
的双精度浮点数数组,用于存储每个员工的酬劳差异。 - 通过一个for循环,代码读取每个员工的信息,并计算其酬劳差异(即两次工资的总和减去总工资),然后将结果存储在
fee
数组中。 - 接着,通过另一个for循环,代码将每个员工的名字和其对应的酬劳差异打印出来。
- 最后,程序返回0,表示正常结束。
代码:
#include<stdio.h>
int main()
{
typedef struct o
{
char name[100];
float salary1;
float salary2;
float pay;
}t;
int n;
scanf("%d",&n);
t people[n];
double fee[n];
for(int i=0;i<n;i++)
{
scanf("%s %f %f %f",&people[i].name,&people[i].salary1,&people[i].salary2,&people[i].pay);
fee[i]=people[i].salary1+people[i].salary2-people[i].pay;
}
for(int i=0;i<n;i++)
{
printf("%s %.2lf\n",people[i].name,fee[i]);
}
return 0;
}
总结:
该程序首先定义了一个结构体来表示员工的信息,然后读取输入来填充这个结构体数组,并计算每个员工的酬劳差异。最后,程序将每个员工的信息(包括名字和酬劳差异)打印出来。