解题思路:
1.根据题目给的公式,输入a,b,c分别为三角形的三条边,S为(a+b+c)/2(这个就是著名的海伦公式),置到这两个东西之后就可以直接求解area了,由于题目要求使用宏定义来写,所以一定要注意宏定义的括号问题,因为宏定义是简单的参数替换,比较愚笨。
2.如果使用C++的话,C++控制小数点后面输出多少位是没有C语言直接%后加数字这么修改来的方面的,其需要先对cout进行设置,然后再输出的时候用setprecision(N)进行设置,其中N为小数点后你希望输出的多少位。
注意事项:
由于本题比较简单,所以题目中的数据基本都是整形
以下是C++的参考代码:
#include<bits/stdc++.h> #define area sqrt(S*(S-a)*(S-b)*(S-c)) #define S ((a+b+c)/2) using namespace std; int main() { int a,b,c; cin>>a>>b>>c; cout.setf(ios::fixed); cout<<setprecision(3)<<area<<endl; return 0; }
0.0分
26 人评分
#include<stdio.h> #include<math.h> #define s(a,b,c) s=(a+b+c)/2; #define area(area,s,a,b,c) area=sqrt(s*(s-a)*(s-b)*(s-c)); int main(void) { float a,b,c,s,area; scanf("%f %f %f",&a,&b,&c); if((a+b)>c&&(a-b)<c) { s(a,b,c); area(area,s,a,b,c); printf("%.3f",area); return 0; } else { printf("您所输入的数不能构成三角形"); return 0; } }
#include<stdio.h> #include<math.h> int main() { double a,b,c,S,area; scanf("%lf%lf%lf",&a,&b,&c); S=(a+b+c)/2; area=sqrt(S*(S-a)*(S-b)*(S-c)); printf("%0.3lf",area); return 0; }
#include <stdio.h> #include <math.h> #define Measure(a ,b ,c) ((a + b + c) / 2.0) #define GetTriangle(a, b, c, s) (sqrt(s * (s - a) * (s - b) * (s - c))) int main(void) { double data_1 = 0, data_2 = 0, data_3 = 0; double S = 0; double Area = 0; scanf("%lf%lf%lf" ,&data_1 ,&data_2 ,&data_3); S = Measure(data_1 ,data_2 ,data_3); Area = GetTriangle(data_1 ,data_2 ,data_3 ,S); printf("%.3lf\n" ,Area); return 0; }
#include<stdio.h> #include<math.h> #define S(a,b,c) (a+b+c)/2 #define A(a,b,c,s) sqrt(s*(s-a)*(s-b)*(s-c)) int main() { double a,b,c,s; scanf("%lf %lf %lf",&a,&b,&c); s=S(a,b,c); printf("%.3f\n",A(a,b,c,s)); return 0; }
#include"stdio.h" #include"math.h" #define S(a,b,c) S=(a+b+c)*1.0/2 #define area(S) area=sqrt(S*(S-a)*(S-b)*(S-c)) int main() { double a,b,c,area,S; scanf("%lf %lf %lf",&a,&b,&c); S(a,b,c); area(S); printf("%.3lf",area); return 0; }
#include<stdio.h> #include<math.h> #define S(a,b,c) S=(a+b+c)*0.5 #define area(a,b,c) sqrt(S*(S-a)*(S-b)*(S-c)) int main(){ float a,b,c,S,area; scanf("%f%f%f",&a,&b,&c); S(a,b,c); printf("%.3f",area(a,b,c)); }
#include<stdio.h> #include<string.h> #define S(a,b,c) d=(a+b+c)/2; #define area(a,b,c,d) a=sqrt(d*(d-a)*(d-b)*(d-c)); int main() { float a,b,c,d; printf("plesse input three numbers\n"); scanf("%f,%f,%f",&a,&b,&c); d=S(a,b,c); a=area(a,b,c,d); printf("%.3f",a); return 0; }
C语言训练-计算一个整数N的阶乘 (C语言代码)浏览:927 |
成绩转换 (C语言代码)浏览:1005 |
C二级辅导-阶乘数列 (C语言代码)浏览:688 |
【金明的预算方案】 (C++代码)浏览:837 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:505 |
图形输出 (C语言代码)浏览:936 |
C二级辅导-等差数列 (C语言代码)浏览:808 |
数列排序 (C语言代码)浏览:606 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:454 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:663 |
菜旺 2024-02-19 15:25:55 |
float a,b,c,s=0,area=0;