#include<stdio.h>
#include<math.h>
double area(double x,double y,double z);
{
double p=(x+y+z)/2;
return sqrt(p*(p-x)(p-y)(p-z));
}
int main()
{
double a1,a2,a3,a4,a5,a6,a7,s;
printf("input 7 sise lengths in the order a1 to a7:\n");
scanf("%lf%lf%lf%lf%lf%lf%lf",&a1,&a2,&a3,&a4,&a5&,a6,&a7);
s=area(a1,a5,a6)+area(a4,a6,a7)+area(a2,a3,a7);
printf("the area of the pentagon is:%.2f\n",s);
return 0;
}
为什么会报错?求解答
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- CSDN专家-link 2021-12-17 19:12关注
double area(double x,double y,double z);
后面的分号删除掉
另外函数里你应该检查一下三条边长度是否能够组成三角形,否则sqrt的参数可能是个负数,会出问题的#include<stdio.h> #include<math.h> double area(double x,double y,double z) { double p=(x+y+z)/2; if(x+y>z || y+z>x || x+z>y) return 0; return sqrt(p*(p-x)*(p-y)*(p-z)); } int main() { double a1,a2,a3,a4,a5,a6,a7,s; printf("input 7 sise lengths in the order a1 to a7:\n"); scanf("%lf%lf%lf%lf%lf%lf%lf",&a1,&a2,&a3,&a4,&a5,&a6,&a7); s=area(a1,a5,a6)+area(a4,a6,a7)+area(a2,a3,a7); printf("the area of the pentagon is:%.2f\n",s); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 2无用
悬赏问题
- ¥15 基于卷积神经网络的声纹识别
- ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
- ¥100 为什么这个恒流源电路不能恒流?
- ¥15 有偿求跨组件数据流路径图
- ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
- ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
- ¥15 CSAPPattacklab
- ¥15 一直显示正在等待HID—ISP
- ¥15 Python turtle 画图
- ¥15 stm32开发clion时遇到的编译问题