当前位置: 首页 > news >正文

常用的启发式算法:探索问题解决的智慧之道

启发式算法是一种通过启发式信息来引导搜索的算法,常用于解决那些在合理时间内难以找到最优解的问题。本文将介绍几种常用的启发式算法,包括贪心算法、遗传算法和模拟退火算法,并提供Java代码实现及测试,帮助读者深入理解这些算法的原理和应用。

1. 贪心算法(Greedy Algorithm)

贪心算法是一种简单而有效的启发式算法,它通过每一步都选择当前状态下最优的解决方案来达到全局最优解。虽然贪心算法不能保证获得最优解,但在某些问题上表现出色,例如最小生成树、最短路径等。以下是贪心算法的Java实现及测试:

import java.util.*;public class GreedyAlgorithm {public static List<Integer> findMinimumSet(int[] nums, int target) {Arrays.sort(nums);List<Integer> result = new ArrayList<>();int sum = 0;for (int i = nums.length - 1; i >= 0; i--) {if (sum + nums[i] <= target) {sum += nums[i];result.add(nums[i]);}}return result;}public static void main(String[] args) {int[] nums = {1, 3, 2, 4, 6, 5};int target = 10;List<Integer> result = findMinimumSet(nums, target);System.out.println("Greedy Algorithm Result: " + result);}
}

2. 遗传算法(Genetic Algorithm)

遗传算法是一种模拟生物进化过程的启发式算法,通过模拟遗传、交叉和变异等操作来搜索解空间中的最优解。遗传算法适用于解决复杂的优化问题,例如旅行商问题、装箱问题等。以下是遗传算法的Java实现及测试:

import java.util.*;public class GeneticAlgorithm {private static final int POPULATION_SIZE = 10;private static final int CHROMOSOME_LENGTH = 8;private static final int MAX_GENERATIONS = 100;private static final double MUTATION_RATE = 0.1;private static Random random = new Random();// 随机生成染色体private static int[] generateChromosome() {int[] chromosome = new int[CHROMOSOME_LENGTH];for (int i = 0; i < CHROMOSOME_LENGTH; i++) {chromosome[i] = random.nextInt(2); // 0或1}return chromosome;}// 计算染色体的适应度(假设目标是所有基因都为1)private static int calculateFitness(int[] chromosome) {int fitness = 0;for (int gene : chromosome) {fitness += gene;}return fitness;}// 选择父代private static int[][] selectParents(int[][] population) {int[][] parents = new int[2][CHROMOSOME_LENGTH];// 根据适应度进行轮盘赌选择int totalFitness = Arrays.stream(population).mapToInt(chromosome -> calculateFitness(chromosome)).sum();int threshold = random.nextInt(totalFitness);int accumulatedFitness = 0;for (int[] chromosome : population) {accumulatedFitness += calculateFitness(chromosome);if (accumulatedFitness >= threshold) {parents[0] = chromosome;break;}}threshold = random.nextInt(totalFitness);accumulatedFitness = 0;for (int[] chromosome : population) {accumulatedFitness += calculateFitness(chromosome);if (accumulatedFitness >= threshold) {parents[1] = chromosome;break;}}return parents;}// 交叉操作private static int[][] crossover(int[] parent1, int[] parent2) {int crossoverPoint = random.nextInt(CHROMOSOME_LENGTH);int[] child1 = new int[CHROMOSOME_LENGTH];int[] child2 = new int[CHROMOSOME_LENGTH];System.arraycopy(parent1, 0, child1, 0, crossoverPoint);System.arraycopy(parent2, crossoverPoint, child1, crossoverPoint, CHROMOSOME_LENGTH - crossoverPoint);System.arraycopy(parent2, 0, child2, 0, crossoverPoint);System.arraycopy(parent1, crossoverPoint, child2, crossoverPoint, CHROMOSOME_LENGTH - crossoverPoint);return new int[][] {child1, child2};}// 变异操作private static void mutate(int[] chromosome) {for (int i = 0; i < CHROMOSOME_LENGTH; i++) {if (random.nextDouble() < MUTATION_RATE) {chromosome[i] = 1 - chromosome[i]; // 0变1,1变0}}}// 遗传算法主函数public static void geneticAlgorithm() {// 初始化种群int[][] population = new int[POPULATION_SIZE][CHROMOSOME_LENGTH];for (int i = 0; i < POPULATION_SIZE; i++) {population[i] = generateChromosome();}// 进化过程for (int generation = 1; generation <= MAX_GENERATIONS; generation++) {// 选择父代int[][] parents = selectParents(population);// 交叉操作int[][] offspring = crossover(parents[0], parents[1]);// 变异操作for (int[] child : offspring) {mutate(child);}// 更新种群population = offspring;// 输出每一代的最优解int maxFitness = 0;for (int[] chromosome : population) {int fitness = calculateFitness(chromosome);if (fitness > maxFitness) {maxFitness = fitness;}}System.out.println("Generation " + generation + ", Max Fitness: " + maxFitness);}}// 测试函数public static void main(String[] args) {geneticAlgorithm(); // 执行遗传算法}
}

3. 模拟退火算法(Simulated Annealing)

模拟退火算法是一种基于物理学原理的启发式算法,通过随机扰动和接受劣解的概率来逐步减小系统温度,从而搜索解空间中的最优解。模拟退火算法适用于解决组合优化、函数优化等问题。以下是模拟退火算法的Java实现及测试:

import java.util.Random;public class SimulatedAnnealing {// 目标函数,这里以一个简单的示例函数为例public static double objectiveFunction(double x) {return Math.sin(x) / x;}// 模拟退火算法实现public static double simulatedAnnealing(double initialTemperature, double coolingRate, double minValue, double maxValue) {Random rand = new Random();double currentSolution = rand.nextDouble() * (maxValue - minValue) + minValue; // 初始解double temperature = initialTemperature; // 初始温度while (temperature > 0.1) { // 设定停止条件double newSolution = currentSolution + (rand.nextDouble() * 2 - 1); // 随机扰动double currentEnergy = objectiveFunction(currentSolution);double neighborEnergy = objectiveFunction(newSolution);if (neighborEnergy > currentEnergy || rand.nextDouble() < Math.exp((currentEnergy - neighborEnergy) / temperature)) {currentSolution = newSolution; // 接受劣解}temperature *= 1 - coolingRate; // 降低温度}return currentSolution;}public static void main(String[] args) {double initialTemperature = 1000; // 初始温度double coolingRate = 0.03; // 温度衰减率double minValue = -10; // 解的最小值范围double maxValue = 10; // 解的最大值范围double result = simulatedAnnealing(initialTemperature, coolingRate, minValue, maxValue);System.out.println("Simulated Annealing Result: " + result);System.out.println("Objective Function Value: " + objectiveFunction(result));}
}

结论

启发式算法是解决复杂问题的有效工具,常用于那些难以找到最优解的问题。本文介绍了贪心算法、遗传算法和模拟退火算法的原理及Java实现,并提供了相应的测试代码。读者通过学习本文,可以深入了解这些常用的启发式算法,并在实际项目中灵活运用,提高问题解决的效率和准确性。

 感谢您阅读本文,欢迎“一键三连”。作者定会不负众望,按时按量创作出更优质的内容。
❤️ 1. 毕业设计专栏,毕业季咱们不慌,上千款毕业设计等你来选。

相关文章:

常用的启发式算法:探索问题解决的智慧之道

启发式算法是一种通过启发式信息来引导搜索的算法&#xff0c;常用于解决那些在合理时间内难以找到最优解的问题。本文将介绍几种常用的启发式算法&#xff0c;包括贪心算法、遗传算法和模拟退火算法&#xff0c;并提供Java代码实现及测试&#xff0c;帮助读者深入理解这些算法…...

docker Harbor私有仓库部署管理

搭建本地私有仓库&#xff0c;但是本地私有仓库的管理和使用比较麻烦&#xff0c;这个原生的私有仓库并不好用&#xff0c;所以我们采用harbor私有仓库&#xff0c;也叫私服&#xff0c;更加人性化。 一、什么是Harbor Harbor是VWware 公司开源的企业级Docker Registry项…...

序列化的不同格式:JSON、XML、TOML、CSON、YAML

前言 这篇文章参考于知乎&#xff0c;进行了一些总结。 正文 首先什么是序列化&#xff0c;数据序列化是从一个系统获取一些信息&#xff0c;将其转换为其它系统可以读取的格式&#xff0c;然后将其传递给其它系统的过程。也就是可以让不同系统“通信”。 序列化需要满足两…...

Mapreduce | 案例

根据提供的数据文件【test.log】 数据文件格式&#xff1a;姓名,语文成绩,数学成绩,英语成绩 完成如下2个案例&#xff1a; &#xff08;1&#xff09;求每个学科的平均成绩 &#xff08;2&#xff09;将三门课程中任意一门不及格的学生过滤出来 &#xff08;1&#xff09;求每…...

U盘文件剪切丢失怎么办?揭秘原因并给出恢复方法

在日常生活和工作中&#xff0c;U盘已成为我们不可或缺的数据存储和传输工具。但有时候&#xff0c;我们在对U盘中的文件进行剪切操作时&#xff0c;会遇到文件丢失的情况。这种突如其来的数据消失往往会让人感到惊慌和困惑。那么&#xff0c;为什么U盘剪切时文件会丢失呢&…...

软件设计师考试---访问控制列表、堆,栈和堆栈、防火墙、数据流图、嵌入式操作、绑定方式、uml、模式、传输协议

访问控制列表 访问控制列表&#xff08;Access Control List&#xff0c;ACL&#xff09; 是一种用于控制对资源&#xff08;如文件、目录、网络资源等&#xff09;访问权限的方法。ACL是在计算机安全领域广泛使用的概念&#xff0c;它允许系统管理员定义哪些用户或系统进程有…...

vlock工具:锁定Linux终端的安全智能方法

虚拟控制台是 Linux 非常重要的功能&#xff0c;它们为系统用户提供 shell 提示&#xff0c;以非图形设置方式使用系统&#xff0c;该设置只能在物理机上使用&#xff0c;而不能远程使用。 用户只需从一个虚拟控制台切换到另一个虚拟控制台即可同时使用多个虚拟控制台会话。 …...

【Linux】Docker 安装部署 Nacos

个人简介&#xff1a;Java领域新星创作者&#xff1b;阿里云技术博主、星级博主、专家博主&#xff1b;正在Java学习的路上摸爬滚打&#xff0c;记录学习的过程~ 个人主页&#xff1a;.29.的博客 学习社区&#xff1a;进去逛一逛~ 【Linux】Docker 安装部署 Nacos docker搜索na…...

纯血鸿蒙APP实战开发——阅读翻页方式案例

介绍 本示例展示手机阅读时左右翻页&#xff0c;上下翻页&#xff0c;覆盖翻页的功能。 效果图预览 使用说明 进入模块即是左右翻页模式。点击屏幕中间区域弹出上下菜单。点击设置按钮&#xff0c;弹出翻页方式切换按钮&#xff0c;点击可切换翻页方式。左右翻页方式可点击翻…...

如何从Mac电脑恢复任何删除的视频

Microsoft Office是包括Mac用户在内的人们在世界各地创建文档时使用的最佳软件之一。该软件允许您创建任何类型的文件&#xff0c;如演示文稿、帐户文件和书面文件。您可以使用 MS Office 来完成。所有Microsoft文档都可以在Mac上使用。大多数情况下&#xff0c;您处理文档&…...

【Halcon 内存泄漏记录 - C#】

Halcon 内存泄漏记录 - C# 1. Bitmap 转 HImage2. new 之后要Dispose()3. 切换配方后&#xff0c;内存会增加4. Parallel.For 嵌套Parallel.For&#xff0c; 会出现问题5. 图像预处理使用需要注意不能直接在原有变量上赋值 1. Bitmap 转 HImage 由于Bitmap 在转化时使用Bitmap…...

MT8370_联发科MTK8370(Genio 510)芯片性能规格参数

MT8370芯片是一款利用超高效的6nm制程工艺打造的边缘AI平台&#xff0c;具有强大的性能和功能。这款芯片集成了六核CPU(2x2.2 GHz Arm Cortex-A78 & 4x2.0 GHz Arm Cortex-A55)、Arm Mali-G57 MC2 GPU、集成的APU(AI处理器)和DSP&#xff0c;以及一个HEVC编码加速引擎&…...

【Qt 学习笔记】Qt常用控件 | 多元素控件 | Table Widget的说明及介绍

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Qt常用控件 | 多元素控件 | Table Widget的说明及介绍 文章编号&#…...

ES全文检索支持拼音和繁简检索

ES全文检索支持拼音和繁简检索 1. 实现目标2. 引入pinyin插件2.1 编译 elasticsearch-analysis-pinyin 插件2.2 安装拼音插件 3. 引入ik分词器插件3.1 已有作者编译后的包文件3.2 只有源代码的版本3.3 安装ik分词插件 4. 建立es索引5.测试检索6. 繁简转换 1. 实现目标 ES检索时…...

【DDR 终端稳压器】Sink and Source DDR Termination Regulator [C] S0 S1 S2 S3 S4 S5 6状态

TPS51200A-Q1 器件通过 EN 功能提供 S3 支持。EN引脚可以连接到终端应用中的SLP_S3信号。当EN 高电平&#xff08;S0 状态&#xff09;时&#xff0c;REFOUT 和 VO 引脚均导通。当EN 低电平&#xff08;S3状态&#xff09;时&#xff0c;VO引脚关断并通过内部放电MOSFET放电时…...

使用IIS部署Vue项目

前提 使用IIS部署Vue项目&#xff0c;后端必须跨域&#xff0c;不要在Vue中用proxy跨域&#xff0c;那个只在dev环境中有用&#xff01; IIS安装&#xff0c;不用全部打勾&#xff0c;有些他默认就是方块 ■ 选择性安装的&#xff0c;就维持原样就可以。 添加网站配置 右键…...

QT+多线程TCP服务器+进阶版

针对之前的服务器&#xff0c;如果子线程工作类里面需要使用socket发送消息&#xff0c;必须要使用信号与槽的方法&#xff0c; 先发送一个信号给父进程&#xff0c;父进程调用socket发送消息&#xff08;原因是QT防止父子进程抢夺同一资源&#xff0c;因此直接规定父子进程不能…...

Java入门基础学习笔记12——变量详解

变量详解&#xff1a; 变量里的数据在计算机中的存储原理。 二进制&#xff1a; 只有0和1&#xff0c; 按照逢2进1的方式表示数据。 十进制转二进制的算法&#xff1a; 除二取余法。 6是110 13是1101 计算机中表示数据的最小单元&#xff1a;一个字节&#xff08;byte&…...

bitmap requires a valid src attribute

关于作者&#xff1a;CSDN内容合伙人、技术专家&#xff0c; 从零开始做日活千万级APP。 专注于分享各领域原创系列文章 &#xff0c;擅长java后端、移动开发、商业变现、人工智能等&#xff0c;希望大家多多支持。 未经允许不得转载 目录 一、导读二、概览三、问题记录四、 推…...

Java刷题-基础篇

目录 题目1&#xff1a;打印1~100内奇数和、偶数和 题目2&#xff1a;计算5的阶乘 题目3&#xff1a;计算 1!2!3!4!5! 的和 题目4&#xff1a;找1~100之间即能被3整除&#xff0c;又能被5整除的数字&#xff0c;要求必须使用break/continue 题目5&#xff1a;实现猜数字小…...

XCTF-web-easyupload

试了试php&#xff0c;php7&#xff0c;pht&#xff0c;phtml等&#xff0c;都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接&#xff0c;得到flag...

【JavaEE】-- HTTP

1. HTTP是什么&#xff1f; HTTP&#xff08;全称为"超文本传输协议"&#xff09;是一种应用非常广泛的应用层协议&#xff0c;HTTP是基于TCP协议的一种应用层协议。 应用层协议&#xff1a;是计算机网络协议栈中最高层的协议&#xff0c;它定义了运行在不同主机上…...

MongoDB学习和应用(高效的非关系型数据库)

一丶 MongoDB简介 对于社交类软件的功能&#xff0c;我们需要对它的功能特点进行分析&#xff1a; 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具&#xff1a; mysql&#xff1a;关系型数据库&am…...

遍历 Map 类型集合的方法汇总

1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...

Python实现prophet 理论及参数优化

文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候&#xff0c;写过一篇简单实现&#xff0c;后期随着对该模型的深入研究&#xff0c;本次记录涉及到prophet 的公式以及参数调优&#xff0c;从公式可以更直观…...

2025 后端自学UNIAPP【项目实战:旅游项目】6、我的收藏页面

代码框架视图 1、先添加一个获取收藏景点的列表请求 【在文件my_api.js文件中添加】 // 引入公共的请求封装 import http from ./my_http.js// 登录接口&#xff08;适配服务端返回 Token&#xff09; export const login async (code, avatar) > {const res await http…...

EtherNet/IP转DeviceNet协议网关详解

一&#xff0c;设备主要功能 疆鸿智能JH-DVN-EIP本产品是自主研发的一款EtherNet/IP从站功能的通讯网关。该产品主要功能是连接DeviceNet总线和EtherNet/IP网络&#xff0c;本网关连接到EtherNet/IP总线中做为从站使用&#xff0c;连接到DeviceNet总线中做为从站使用。 在自动…...

ABAP设计模式之---“简单设计原则(Simple Design)”

“Simple Design”&#xff08;简单设计&#xff09;是软件开发中的一个重要理念&#xff0c;倡导以最简单的方式实现软件功能&#xff0c;以确保代码清晰易懂、易维护&#xff0c;并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计&#xff0c;遵循“让事情保…...

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

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

Python竞赛环境搭建全攻略

Python环境搭建竞赛技术文章大纲 竞赛背景与意义 竞赛的目的与价值Python在竞赛中的应用场景环境搭建对竞赛效率的影响 竞赛环境需求分析 常见竞赛类型&#xff08;算法、数据分析、机器学习等&#xff09;不同竞赛对Python版本及库的要求硬件与操作系统的兼容性问题 Pyth…...