三分算法与DeepSeek辅助证明是单峰函数

news2025/6/12 8:15:05

前置

单峰函数有唯一的最大值,最大值左侧的数值严格单调递增,最大值右侧的数值严格单调递减。

单谷函数有唯一的最小值,最小值左侧的数值严格单调递减,最小值右侧的数值严格单调递增。

三分的本质

三分和二分一样都是通过不断缩小区间范围直到找到要查的值,优化查找值的时间复杂度。二分是在单调序列中查找一个值,三分是在单峰函数或单谷函数中查找极值。

三分有两个mid,可确定极值位置,mid1 = L + (R - L) / 3,mid2 = R - (R - L) / 3。对于单峰函数,当f(mid1) < f(mid2)时,mid1和mid2要么在极值左侧,要么在极值两侧,这两种情况极值一定在mid1右侧,L = mid1,当f(mid1) > f(mid2)时,mid1和mid2要么在极值右侧,要么在极值两侧,这两种情况极值一定在mid2左侧,R  = mid2;

二分没法在单峰函数或单谷函数中查找极值,因为单峰或单谷函数没有单调性,所以需要三分。

能用三分则该问题的某部分是单峰或单谷函数。

三分求解步骤

1.问题的某部分是否具有单峰函数或单谷函数的性质。

2.实现三分

三分基础

P3382 三分 - 洛谷

已明确是单峰函数,可用三分。

代码如下:

#include <iostream>
#include <iomanip>
#include <cmath>
using namespace std;

typedef long long LL;

const LL Maxn = 15;

double vct[Maxn];

double func(double x, LL n) {
    double res = 0.0;
    double x_pow = 1.0;
    for (LL i = 0; i <= n; ++i) {
        res += vct[i] * x_pow;
        x_pow *= x;
    }
    return res;
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);

    LL n;
    double L, R, eps = 1e-7, mid;
    cin >> n >> L >> R;
    for (LL i = n; i >= 0; --i)  cin >> vct[i];

    while (L + eps <  R) {
        mid = (L + R) / 2;
        if (func(mid - eps, n) > func(mid + eps, n))  R = mid;
        else  L = mid;
    }

    cout << fixed << setprecision(5) << L;

    return 0;
}

注意精度,精度的处理类似实数域中的二分做法。

一般mid1取[L, R]的三分之一位置,mid2取[L, R]的三分之二位置,如此每次区间缩小到区间的三分之二,若mid1,mid2,取[L, R]的二分之一的位置的左右两侧,则区间每次缩小到区间的二分之一左右,时间复杂度接近二分。

三分套三分

P2571 [SCOI2010] 传送带 - 洛谷

两点间中的所有线直线的距离最短,所以都走直线,那么大概走法如下图,只需确定E点和F点即可。

设两点间的直线距离为dis(x, y),走的总距离为S = dis(A, E) / P + dis(E, F) / R + dis(F, D) / Q。设E已知,则只需关心f(E) = dis(E, F) / R + dis(F, D) / Q,若f(E)是个单峰或单谷函数即可用三分查找F的最优解,此时 S = dis(A, E) / p + f(E),若dis(A, E) / p + f(E)是个单峰或单谷函数即可用三分查找E的最优解,需要严格的数学证明,可我不会,就问了DeepSeek,它给出了如下图的详细证明。

DeepSeek证明了一定是单峰函数,则可用三分法求解。

代码如下:

#include <iostream>
#include <iomanip>
#include <cmath>
using namespace std;

typedef long long LL;

const double eps = 1e-8;

double ax, ay, bx, by, cx, cy, dx, dy, p, Q, r;

double getDis(double nx, double ny, double mx, double my) {
    return sqrt((nx - mx) * (nx - mx) + (ny - my) * (ny - my));
}

double in_ter(double ex, double ey) {
    double Lx = cx, Ly = cy, Rx = dx, Ry = dy;
    double f1x = 0.0, f1y = 0.0, f2x = 0.0, f2y = 0.0, t1 = 0.0, t2 = 0.0;

    while (getDis(Lx, Ly, Rx, Ry) > eps) {
        f1x = Lx + (Rx - Lx) / 3.0;
        f1y = Ly + (Ry - Ly) / 3.0;
        f2x = Rx - (Rx - Lx) / 3.0;
        f2y = Ry - (Ry - Ly) / 3.0;

        t1 = getDis(ex, ey, f1x, f1y) / r + getDis(f1x, f1y, dx, dy) / Q;
        t2 = getDis(ex, ey, f2x, f2y) / r + getDis(f2x, f2y, dx, dy) / Q;

        if (t1 < t2) {
            Rx = f2x;
            Ry = f2y;
        } else {
            Lx = f1x;
            Ly = f1y;
        }
    }

    return getDis(ex, ey, Lx, Ly) / r + getDis(Lx, Ly, dx, dy) / Q;
}

double out_ter() {
    double Lx = ax, Ly = ay, Rx = bx, Ry = by;
    double e1x = 0.0, e1y = 0.0, e2x = 0.0, e2y = 0.0, t1 = 0.0, t2 = 0.0;

    while (getDis(Lx, Ly, Rx, Ry) > eps) {
        e1x = Lx + (Rx - Lx) / 3.0;
        e1y = Ly + (Ry - Ly) / 3.0;
        e2x = Rx - (Rx - Lx) / 3.0;
        e2y = Ry - (Ry - Ly) / 3.0;

        t1 = getDis(ax, ay, e1x, e1y) / p + in_ter(e1x, e1y);
        t2 = getDis(ax, ay, e2x, e2y) / p + in_ter(e2x, e2y);

        if (t1 < t2) {
            Rx = e2x;
            Ry = e2y;
        } else {
            Lx = e1x;
            Ly = e1y;
        }
    }
    return getDis(ax, ay, Lx, Ly) / p + in_ter(Lx, Ly);
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);

    cin >> ax >> ay >> bx >> by >> cx >> cy >> dx >> dy >> p >> Q >> r;

    if (getDis(ax, ay, bx, by) < eps) {
        cout << fixed << setprecision(2) << in_ter(ax, ay);
    } else {
        cout << fixed << setprecision(2) << out_ter();
    }

    return 0;
}

最后的值是double型的,虽然输入数据是整数,但用double型表示,避免转换。

f1x为Lx,Rx三分之一的位置,f1y为Ly,Ry三分之一的位置,坐标必须能对在一起,否则(f1x,f1t)不在线段AB上。

总结

数学很重要,P2571就需要数学,没有数学证明是没法用三分的,也就没法写出这篇实现代码。要练习使用AI工具,缺知识的时候AI工具会派上大用场,关键是拆解问题规模,提出明确的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2407167.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

宇树科技,改名了!

提到国内具身智能和机器人领域的代表企业&#xff0c;那宇树科技&#xff08;Unitree&#xff09;必须名列其榜。 最近&#xff0c;宇树科技的一项新变动消息在业界引发了不少关注和讨论&#xff0c;即&#xff1a; 宇树向其合作伙伴发布了一封公司名称变更函称&#xff0c;因…

【网络安全】开源系统getshell漏洞挖掘

审计过程&#xff1a; 在入口文件admin/index.php中&#xff1a; 用户可以通过m,c,a等参数控制加载的文件和方法&#xff0c;在app/system/entrance.php中存在重点代码&#xff1a; 当M_TYPE system并且M_MODULE include时&#xff0c;会设置常量PATH_OWN_FILE为PATH_APP.M_T…

uniapp 开发ios, xcode 提交app store connect 和 testflight内测

uniapp 中配置 配置manifest 文档&#xff1a;manifest.json 应用配置 | uni-app官网 hbuilderx中本地打包 下载IOS最新SDK 开发环境 | uni小程序SDK hbulderx 版本号&#xff1a;4.66 对应的sdk版本 4.66 两者必须一致 本地打包的资源导入到SDK 导入资源 | uni小程序SDK …

Git 3天2K星标:Datawhale 的 Happy-LLM 项目介绍(附教程)

引言 在人工智能飞速发展的今天&#xff0c;大语言模型&#xff08;Large Language Models, LLMs&#xff09;已成为技术领域的焦点。从智能写作到代码生成&#xff0c;LLM 的应用场景不断扩展&#xff0c;深刻改变了我们的工作和生活方式。然而&#xff0c;理解这些模型的内部…

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…

C++ 设计模式 《小明的奶茶加料风波》

&#x1f468;‍&#x1f393; 模式名称&#xff1a;装饰器模式&#xff08;Decorator Pattern&#xff09; &#x1f466; 小明最近上线了校园奶茶配送功能&#xff0c;业务火爆&#xff0c;大家都在加料&#xff1a; 有的同学要加波霸 &#x1f7e4;&#xff0c;有的要加椰果…

【MATLAB代码】基于最大相关熵准则(MCC)的三维鲁棒卡尔曼滤波算法(MCC-KF),附源代码|订阅专栏后可直接查看

文章所述的代码实现了基于最大相关熵准则(MCC)的三维鲁棒卡尔曼滤波算法(MCC-KF),针对传感器观测数据中存在的脉冲型异常噪声问题,通过非线性加权机制提升滤波器的抗干扰能力。代码通过对比传统KF与MCC-KF在含异常值场景下的表现,验证了后者在状态估计鲁棒性方面的显著优…

代码规范和架构【立芯理论一】(2025.06.08)

1、代码规范的目标 代码简洁精炼、美观&#xff0c;可持续性好高效率高复用&#xff0c;可移植性好高内聚&#xff0c;低耦合没有冗余规范性&#xff0c;代码有规可循&#xff0c;可以看出自己当时的思考过程特殊排版&#xff0c;特殊语法&#xff0c;特殊指令&#xff0c;必须…

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来&#xff0c;在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂&#xff0c;网络攻击、数据泄露等事件频发&#xff0c;现行法律已难以完全适应新的风险挑战。 2025年3月28日&#xff0c;国家网信办会同相关部门起草了《网络安全…

计算机基础知识解析:从应用到架构的全面拆解

目录 前言 1、 计算机的应用领域&#xff1a;无处不在的数字助手 2、 计算机的进化史&#xff1a;从算盘到量子计算 3、计算机的分类&#xff1a;不止 “台式机和笔记本” 4、计算机的组件&#xff1a;硬件与软件的协同 4.1 硬件&#xff1a;五大核心部件 4.2 软件&#…

C# 表达式和运算符(求值顺序)

求值顺序 表达式可以由许多嵌套的子表达式构成。子表达式的求值顺序可以使表达式的最终值发生 变化。 例如&#xff0c;已知表达式3*52&#xff0c;依照子表达式的求值顺序&#xff0c;有两种可能的结果&#xff0c;如图9-3所示。 如果乘法先执行&#xff0c;结果是17。如果5…

打手机检测算法AI智能分析网关V4守护公共/工业/医疗等多场景安全应用

一、方案背景​ 在现代生产与生活场景中&#xff0c;如工厂高危作业区、医院手术室、公共场景等&#xff0c;人员违规打手机的行为潜藏着巨大风险。传统依靠人工巡查的监管方式&#xff0c;存在效率低、覆盖面不足、判断主观性强等问题&#xff0c;难以满足对人员打手机行为精…

[大语言模型]在个人电脑上部署ollama 并进行管理,最后配置AI程序开发助手.

ollama官网: 下载 https://ollama.com/ 安装 查看可以使用的模型 https://ollama.com/search 例如 https://ollama.com/library/deepseek-r1/tags # deepseek-r1:7bollama pull deepseek-r1:7b改token数量为409622 16384 ollama命令说明 ollama serve #&#xff1a…

逻辑回归暴力训练预测金融欺诈

简述 「使用逻辑回归暴力预测金融欺诈&#xff0c;并不断增加特征维度持续测试」的做法&#xff0c;体现了一种逐步建模与迭代验证的实验思路&#xff0c;在金融欺诈检测中非常有价值&#xff0c;本文作为一篇回顾性记录了早年间公司给某行做反欺诈预测用到的技术和思路。百度…

FFmpeg:Windows系统小白安装及其使用

一、安装 1.访问官网 Download FFmpeg 2.点击版本目录 3.选择版本点击安装 注意这里选择的是【release buids】&#xff0c;注意左上角标题 例如我安装在目录 F:\FFmpeg 4.解压 5.添加环境变量 把你解压后的bin目录&#xff08;即exe所在文件夹&#xff09;加入系统变量…

[ACTF2020 新生赛]Include 1(php://filter伪协议)

题目 做法 启动靶机&#xff0c;点进去 点进去 查看URL&#xff0c;有 ?fileflag.php说明存在文件包含&#xff0c;原理是php://filter 协议 当它与包含函数结合时&#xff0c;php://filter流会被当作php文件执行。 用php://filter加编码&#xff0c;能让PHP把文件内容…

Golang——9、反射和文件操作

反射和文件操作 1、反射1.1、reflect.TypeOf()获取任意值的类型对象1.2、reflect.ValueOf()1.3、结构体反射 2、文件操作2.1、os.Open()打开文件2.2、方式一&#xff1a;使用Read()读取文件2.3、方式二&#xff1a;bufio读取文件2.4、方式三&#xff1a;os.ReadFile读取2.5、写…

从 GreenPlum 到镜舟数据库:杭银消费金融湖仓一体转型实践

作者&#xff1a;吴岐诗&#xff0c;杭银消费金融大数据应用开发工程师 本文整理自杭银消费金融大数据应用开发工程师在StarRocks Summit Asia 2024的分享 引言&#xff1a;融合数据湖与数仓的创新之路 在数字金融时代&#xff0c;数据已成为金融机构的核心竞争力。杭银消费金…

R 语言科研绘图第 55 期 --- 网络图-聚类

在发表科研论文的过程中&#xff0c;科研绘图是必不可少的&#xff0c;一张好看的图形会是文章很大的加分项。 为了便于使用&#xff0c;本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中&#xff0c;获取方式&#xff1a; R 语言科研绘图模板 --- sciRplothttps://mp.…

LabVIEW双光子成像系统技术

双光子成像技术的核心特性 双光子成像通过双低能量光子协同激发机制&#xff0c;展现出显著的技术优势&#xff1a; 深层组织穿透能力&#xff1a;适用于活体组织深度成像 高分辨率观测性能&#xff1a;满足微观结构的精细研究需求 低光毒性特点&#xff1a;减少对样本的损伤…