IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 运筹学 黄金分割法 JAVA实现 -> 正文阅读

[数据结构与算法]运筹学 黄金分割法 JAVA实现

import java.util.*;

public class Goldstein {
    public static void main(String[]args) {
        //f(x)=1*x^3-2*x^1+1*x^0
        double[][]f=new double[][] {{1,3},{-2,1},{1,0}};//矩阵f最后映射为函数,每个f[i][0]表示系数,f[i][1]表示次方数
        int a=0,b=2;//初始范围

        GsMain gm=new GsMain(f,a,b);//根据函数,初始范围创建

        gm.t=0.618;//可以修改分割比例
        gm.e=0.2;//可以修改精度

        double ans=gm.main();//计算,并返回最终结果

        gm.visit();//展示计算过程

        System.out.println("最终结果:"+ans);
    }
}
class GsMain {
    double[][]f;//是个n*2矩阵,每列第一个元素是系数,第二个元素是次方
    final double T=(-1+Math.pow(5,1.0/2))/2;//默认分割比例
    double t;//可以设置比例,例如0.618
    double a,b,a0,b0;//a0,b0记录第i次起始结果,a,b记录变化后的结果
    double fa,fb;//f(a),f(b)
    double e;//精度
    final double E=0.2;//默认精度
    List<String> list=new ArrayList<>();//存储每次运行结果
    public GsMain(double[][]f,double a,double b) {
        this.f=f;
        this.t=T;
        this.a=a;
        this.b=b;
        a0=a;
        b0=b;
        e=E;
    }

    public double main() {
        int count=0;
        String s=String.format("%4s"+"%6s%6s%6s%6s%14s%6s","次数","a","b","f(a)","f(b)","[a,b]","|b-a|");
        list.add(s);
        while(true) {
            if(++count>20) {
                break;
            }
            a=a0+(1-t)*(b0-a0);
            b=a0+t*(b0-a0);
            setFab();//设置f(a),f(b)

            if(fa<=fb) {
                //删除右区间
                //以下两行用于记录每轮数据,可忽略
                s=String.format("%4d"+"%6.3f%6.3f%6.3f%6.3f[%6.3f,%6.3f]%6.3f",count,a,b,fa,fb,a0,b,b-a0);
                list.add(s);

                a=a0;//左边界重置
                b0=b;//右边界修改
            } else {
                //删除左区间
                //以下两行用于记录每轮数据,可忽略
                s=String.format("%4d"+"%6.3f%6.3f%6.3f%6.3f[%6.3f,%6.3f]%6.3f",count,a,b,fa,fb,a,b0,b0-a);
                list.add(s);

                b=b0;
                a0=a;
            }

            if(Math.abs(b-a)<e) {
                break ;
            }
        }
        return (a+b)/2;
    }
    //根据a,b的值设置fa,fb
    void setFab() {
        //系数
        fa=0;
        fb=0;
        for(double[]fi:f) {
            //次方
            fa+=fi[0]*Math.pow(a,fi[1]);
            fb+=fi[0]*Math.pow(b,fi[1]);
        }
    }
    void visit() {
        for(String s:list) {
            System.out.println(s);
        }
    }
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-11 15:58:41  更:2021-12-11 15:59:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 2:21:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码