如图,有一块玉米地,位于一条东西向公路的北侧,南北向公路的东侧。第一个顶点距离南北路750米,东西路550米;第二个顶点距离南北路850米,东西路50米;第三个顶点距离南北路50米,东西路250;第四个顶点距离南北路150米,东西路450米。该块地种植玉米,收获的总产量为120吨,求玉米每亩产量为多少千克?要求编写程序求解该问题。
编程要求:
程序中至少要有两个函数,函数的功能如下:
(1)编写函数计算两点之间的距离,从而算术图中四边形的四个边的长度以及一个对角线的长的;
(2)根据海伦公式编写一个计算三角向面积的函数;
说明:
1平方米=0.0015亩
输入格式:
一行中输入8个实数,每个数之间用空格隔开。从左到右每两个一组,每组表示一个点的横坐标和纵坐标。
输出格式:
输出一个实数,表示玉米的亩产量。输出保留2位小数。
#include <stdio.h>
#include <math.h>
double side(double* p1, double* p2);// 计算边的长度以及对角线的长度函数的声明
double area(double a, double b, double c);// 海伦公式计算三角形面积函数的声明
int main() {
double coordinate[4][2];// 四个坐标
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 2; j++) {
scanf("%lf", &coordinate[i][j]);
}
}
double length[5];// 四个边长
for (int i = 0; i < 4; i++) {
if (i + 1 == 4) {
length[i] = side(&coordinate[3], &coordinate[0]);
}
else {
length[i] = side(&coordinate[i], &coordinate[i + 1]);
}
}
length[4] = side(&coordinate[1], &coordinate[3]);// 一条对角线长度
double S1, S2;
S1 = area(length[0], length[3], length[4]);// 上半部分三角形面积
S2 = area(length[1], length[2], length[4]);// 下半部分三角形面积
double S = S1 + S2;// 种植总面积
double mu = S * 0.0015;// 平方米 ==》亩
double aver = 120 * 1E3 / mu;// 计算平均产量kg/亩
printf("%.2lf\n", aver);
return 0;
}
double side(double* p1, double* p2) {
double length;
length = sqrt(pow(*p1 - *p2, 2) + pow(*(p1 + 1) - *(p2 + 1), 2));
return length;
}
double area(double a, double b, double c) {
double p = (a + b + c) / 2;
return sqrt(p * (p - a) * (p - b) * (p - c));
}
运行结果
这道题细心一点,难度并不是很大,理清思路还是很容易写出来的。