博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
三分法
阅读量:6275 次
发布时间:2019-06-22

本文共 943 字,大约阅读时间需要 3 分钟。

三分法用来求解函数的极值,极值左右区间满足单调性。

我们使用类似二分的思想来求解 极大值(极小值同理):

我们定义 \(\displaystyle mid = \frac{l+r}{2}\)\(\displaystyle mmid = \frac{mid+r}{2}\),分类讨论:

  • 如果 \(f(mid) > f(mmid)\)
    • 如果二者在同侧,\(f(mid)\) 更靠近 极大值,舍去 \((mmid, r]\) 区间;
    • 如果二者在极大值两侧,舍去其中一边都可以,不影响答案区间。
  • 如果 \(f(mid) < f(mmid)​\)
    • 如果二者在同侧,\(f(mmid)\) 更靠近 极大值,舍去 \([l, mid)\) 区间;
    • 如果二者在极大值两侧,舍去其中一边都可以,不影响答案区间。
  • 如果 \(f(mid) = f(mmid)\)
    • 二者一定在极大值两侧,舍去其中一边都可以。

容易实现。

以下是代码:(题面:)

#include 
#define eps 1e-6int n; double l, r, a[14], mid, mmid;inline double calc(double x) { double res = 0; for (int i=0; i<=n; i++) res = res * x + a[i]; return res;}int main() { scanf("%d%lf%lf", &n, &l, &r); for (int i=0; i<=n; i++) scanf("%lf", &a[i]); while (r > l + eps) { mid = (l + r) / 2.0; mmid = (mid + r) / 2.0; if (calc(mid) > calc(mmid)) r = mmid; else l = mid; } printf("%.5f\n", l); return 0;}

转载于:https://www.cnblogs.com/greyqz/p/9532893.html

你可能感兴趣的文章
迷人的卡耐基说话术
查看>>
PHP导出table为xls出现乱码解决方法
查看>>
PHP问题 —— 丢失SESSION
查看>>
Java中Object类的equals()和hashCode()方法深入解析
查看>>
数据库
查看>>
Vue------第二天(计算属性、侦听器、绑定Class、绑定Style)
查看>>
dojo.mixin(混合进)、dojo.extend、dojo.declare
查看>>
Python 数据类型
查看>>
iOS--环信集成并修改头像和昵称(需要自己的服务器)
查看>>
PHP版微信权限验证配置,音频文件下载,FFmpeg转码,上传OSS和删除转存服务器本地文件...
查看>>
教程前言 - 回归宣言
查看>>
PHP 7.1是否支持操作符重载?
查看>>
Vue.js 中v-for和v-if一起使用,来判断select中的option为选中项
查看>>
Java中AES加密解密以及签名校验
查看>>
定义内部类 继承 AsyncTask 来实现异步网络请求
查看>>
VC中怎么读取.txt文件
查看>>
如何清理mac系统垃圾
查看>>
企业中最佳虚拟机软件应用程序—Parallels Deskto
查看>>
送给“正在纠结”、“准备纠结”的前端开发们
查看>>
Nginx配置文件详细说明
查看>>