计算亩地平均产量

如图,有一块玉米地,位于一条东西向公路的北侧,南北向公路的东侧。第一个顶点距离南北路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));
}

运行结果

 这道题细心一点,难度并不是很大,理清思路还是很容易写出来的。

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Black—slience

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值