iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Java贪心算法实例分析
  • 699
分享到

Java贪心算法实例分析

2023-06-29 05:06:51 699人浏览 泡泡鱼
摘要

这篇“Java贪心算法实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java贪心算法实例分析”文章吧。贪心算法贪心算

这篇“Java贪心算法实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java贪心算法实例分析”文章吧。

贪心算法

贪心算法 (Greedy AlGorithm) 指的是在每一步选择中都采取在当前状态下最好或最优的选择, 从而希望导致结果是最好或最优的算法. 贪心算法得到的结果不一定是最优的结果, 但是都是相对近似最优的结果.

Java贪心算法实例分析

贪心算法的优缺点:

  • 优点: 贪心算法的代码十分简单

  • 缺点: 很难确定一个问题是否可以用贪心算法解决

电台覆盖问题

假设存在以下的广播台, 以及广播台可以覆盖的地区:

广播台覆盖地区
K1北京, 上海, 天津
K2北京, 广州, 深圳
K3上海, 杭州, 成都
K4上海, 天津
K5杭州, 大连

贪心算法的核心思想:

  • 把所有需要覆盖的地区取集合

  • 从电台中取覆盖集合中地区最多的一个

  • 集合中去除已覆盖地区, 继续匹配

代码实现

import java.util.ArrayList;import java.util.Arrays;import java.util.HashMap;import java.util.HashSet;public class 贪心算法 {    // 集合, 存放广播台    static HashMap<String, HashSet<String>> broadcasts = new HashMap<>();    // 集合, 存放地区    static HashSet<String> areas = new HashSet<String>();    // 贪心算法    public static ArrayList<String> Greedy() {        // 创建数组存放结果        ArrayList<String> selects = new ArrayList<>();        // 循环直至地区都覆盖        while (areas.size() != 0) {            // 存放交集最大的广播台            String maxKey = null;            // 存放交集最大的值            int maxKeySize = 0;            // 遍历每个剩余电台            for (String key : broadcasts.keySet()) {                // 取出交集个数                int currSize = getRetainSize(key);                // 替换当前最大                if (currSize > 0 && currSize > maxKeySize) {                    maxKey = key;                    maxKeySize = currSize;                }            }            // 添加广播台到结果            selects.add(maxKey);            // 移除广播台            areas.removeAll(broadcasts.get(maxKey));        }        return selects;    }    // 剩余数量    public static int getRetainSize(String key) {        // 如果为空返回0        if (key == null) return 0;        // 存放key对应的地区集合        HashSet<String> tempSet = new HashSet<>();        // 取key对应的地区        tempSet.addAll(broadcasts.get(key));        // 取交集        tempSet.retainAll(areas);        return tempSet.size();    }    public static void main(String[] args) {//        | K1 | 北京, 上海, 天津 |//        | K2 | 北京, 广州, 深圳 |//        | K3 | 上海, 杭州, 成都 |//        | K4 | 上海, 天津 |//        | K5 | 杭州, 大连 |        // 创建广播台        HashSet<String> K1 = new HashSet<>(Arrays.asList("北京", "上海", "天津"));        HashSet<String> K2 = new HashSet<>(Arrays.asList("北京", "广州", "深圳"));        HashSet<String> K3 = new HashSet<>(Arrays.asList("上海", "杭州", "成都"));        HashSet<String> K4 = new HashSet<>(Arrays.asList("上海", "天津"));        HashSet<String> K5 = new HashSet<>(Arrays.asList("杭州", "大连"));        // 加入map        broadcasts.put("K1", K1);        broadcasts.put("K2", K2);        broadcasts.put("K3", K3);        broadcasts.put("K4", K4);        broadcasts.put("K5", K5);        areas.addAll(K1);        areas.addAll(K2);        areas.addAll(K3);        areas.addAll(K4);        areas.addAll(K5);        // 调试输出        System.out.println(broadcasts);        System.out.println(areas);        ArrayList<String> result = Greedy();        System.out.println(result);    }}

以上就是关于“Java贪心算法实例分析”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: Java贪心算法实例分析

本文链接: https://www.lsjlt.com/news/322818.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java贪心算法实例分析
    这篇“Java贪心算法实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java贪心算法实例分析”文章吧。贪心算法贪心算...
    99+
    2023-06-29
  • Java中使用贪心算法的示例分析
    小编给大家分享一下Java中使用贪心算法的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!贪心算法由于贪心算法本身的特殊性,我们在使用贪心算法之前必须要进行证明,保证算法满足贪心选择性质。具体的证明方法无外乎就是通过...
    99+
    2023-06-15
  • 贪心算法(贪婪算法)
    贪心算法(贪婪算法) 文章目录 **贪心算法思想**选择排序平衡字符串买卖股票的最佳时机跳跃游戏钱币找零多机器调度问题举办活动数量最多无重叠区间 贪心算法思想 ​ 1.贪心算法(又称贪婪算法)是指,在对问题求解时,总是...
    99+
    2023-08-21
    贪心算法 算法 java 数据结构
  • Python实现贪心算法的示例
    目录一、贪心算法简介二、解决思路1.同学导师给的思路2.问题分解三、算法代码实现四、算法测试结果五、算法复杂性分析今天一个研究生同学问我一个问题,问题如下: 超市有m个顾客要结账,每...
    99+
    2024-04-02
  • java贪心算法初学感悟图解及示例分享
    算法简介 1)贪心算法是指在对问题进行求解时,在每一步选择中都采取最好或者最优(即最有利)的选择,从而希望能够导致是最好或者最优的算法 2)贪心算法所得到的结果不一定是最优的结果(有...
    99+
    2024-04-02
  • 如何理解java贪心算法
    今天就跟大家聊聊有关如何理解java贪心算法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。算法简介1)贪心算法是指在对问题进行求解时,在每一步选择中都采取最好或者最优(即最有利)的选...
    99+
    2023-06-21
  • C++实现贪心算法的示例详解
    目录区间问题区间选点最大不相交区间数量区间分组区间覆盖Huffman树合并果子排序不等式排队打水绝对值不等式货舱选址区间问题 区间选点 给定 N 个闭区间 [ai,bi],请你在数轴...
    99+
    2024-04-02
  • 怎么使用Java贪心算法
    这篇文章主要介绍“怎么使用Java贪心算法”,在日常操作中,相信很多人在怎么使用Java贪心算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Java贪心算法”的疑惑...
    99+
    2024-04-02
  • 【算法】反悔贪心
    文章目录 反悔贪心力扣题目列表630. 课程表 III871. 最低加油次数LCP 30. 魔塔游戏2813. 子序列最大优雅度 洛谷题目列表P2949 [USACO09OPEN] Wor...
    99+
    2023-09-12
    算法 反悔贪心 贪心
  • Java贪心算法超详细讲解
    目录什么是贪心算法通过场景理解算法问题分析总结什么是贪心算法 在分析和求解某个问题时,在每一步的计算选择上都是最优的或者最好的,通过这种方式期望最终的计算的结果也是最优的。也就是说,...
    99+
    2024-04-02
  • Java贪心算法之Prime算法原理与实现方法详解
    本文实例讲述了Java贪心算法之Prime算法原理与实现方法。分享给大家供大家参考,具体如下:Prime算法:是一种穷举查找算法来从一个连通图中构造一棵最小生成树。利用始终找到与当前树中节点权重最小的边,找到节点,加到最小生成树的节点集合中...
    99+
    2023-05-31
    java 贪心算法 prime算法
  • 贪心算法是什么
    本篇文章给大家分享的是有关贪心算法是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1 概念贪心的意思在于在作出选择时,每次都要选择对自身最为有利的结果,保证自身利益的最大化...
    99+
    2023-06-19
  • Python 经典贪心算法之Prim算法案例详解
    最小生成树的Prim算法也是贪心算法的一大经典应用。Prim算法的特点是时刻维护一棵树,算法不断加边,加的过程始终是一棵树。 Prim算法过程: 一条边一条边地加, 维护一棵树。 初...
    99+
    2024-04-02
  • C++算法精讲之贪心算法
    目录选择排序平衡字符串买股票的最佳时机跳跃游戏钱币找零多机调度问题活动选择无重叠区间选择排序 我们熟知的选择排序,其采用的就是贪心策略。 它所采用的贪心策略即为每次从未排序的数据中选...
    99+
    2024-04-02
  • Java算法之BFS,DFS,动态规划和贪心算法的实现
    目录前言广度优先搜索深度优先搜索动态规划贪心总结前言 广度优先搜索(BFS)和深度优先搜索(DFS)是图遍历算法中最常见的两种算法,主要用于解决搜索和遍历问题。动态规划和贪心算法则用...
    99+
    2023-05-14
    Java BFS Java DFS Java动态规划 Java贪心
  • 贪心算法①--使用贪心算法思想解活动安排问题-python
    '''一、具有贪心选择结构 复杂问题可以划分成小问题解决二、具有贪心选择性质 是否能够用贪心选择开始一个最优起点,使用贪心选择能否得到一个完整解案例1:最优装载问题 有n个集装箱需要装上一艘重量为W的轮船。 其中...
    99+
    2023-10-26
    贪心算法 python 算法 数据结构 pycharm
  • C++贪心算法实现马踏棋盘
    本文实例为大家分享了C++贪心算法实现马踏棋盘的具体代码,供大家参考,具体内容如下 算法实现流程: 步骤1:初始化马的位置(结构体horse {x, y}) 步骤2:确定马从当前点...
    99+
    2024-04-02
  • Java算法之BFS,DFS,动态规划和贪心算法如何实现
    本篇内容主要讲解“Java算法之BFS,DFS,动态规划和贪心算法如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java算法之BFS,DFS,动态规划和贪心算法如何实现”吧!广度优先搜索...
    99+
    2023-07-05
  • 如何使用贪心算法
    这篇文章主要讲解了“如何使用贪心算法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用贪心算法”吧!活动规则客户购买 X 瓶酒,就可以用 Y 个空酒瓶来...
    99+
    2024-04-02
  • 贪心算法原理及在Java中的使用
    目录贪心算法 区间调度问题 好了,说了这么多,那针对该问题正确的贪心策略到底是哪个?应用 总结 贪心算法 由于贪心算法本身的特殊性,我们在使用贪心算法之前必须要进行证明,保证算法满...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作