注意:
1.学习编写带参宏定义
2.学习使用牛顿迭代法求解平方根

  1. #include<stdio.h>
  2. double fabs_my(double x);
  3. double sqrt_my(double x);
  4. #define S(a, b, c) (a + b + c) / 2.0
  5. #define area(S, a, b, c) sqrt_my(S*(S-a)*(S-b)*(S-c))
  6. int main()
  7. {
  8. double a, b, c, S, area;
  9. scanf("%lf%lf%lf", &a, &b, &c);
  10. S = S(a, b, c);
  11. area = area(S, a, b, c);
  12. printf("%0.3lf\n", area);
  13. return 0;
  14. }
  15. // 牛顿迭代法计算平方根
  16. double sqrt_my(double x)
  17. {
  18. double a = 1.0, a1 = x, precision = 1E-5;
  19. do
  20. {
  21. a1 = a;
  22. a = (a1 + x / a1) / 2;
  23. }
  24. while(fabs_my(a - a1) > precision);
  25. return a;
  26. }
  27. // 定义绝对值函数
  28. double fabs_my(double x)
  29. {
  30. return (x >= 0 ? x : -x);
  31. }
点赞(0)
 

6 分

2 人评分

 

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论