java-贪心算法

1. 霍夫曼编码(Huffman Coding)

描述
霍夫曼编码是一种使用变长编码表对数据进行编码的算法,由David A. Huffman在1952年发明。它是一种贪心算法,用于数据压缩。霍夫曼编码通过构建一个二叉树(霍夫曼树),树中的每个叶子节点代表一个字符,树的权重表示字符出现的频率。构建树的过程中,总是将两个权重最小的节点合并。

Java案例

import java.util.PriorityQueue;public class HuffmanCoding {static class Node {char data;int frequency;Node left, right;Node(char data, int frequency) {this.data = data;this.frequency = frequency;left = right = null;}}// 构建霍夫曼树static Node buildHuffmanTree(char data[], int frequency[]) {PriorityQueue<Node> minHeap = new PriorityQueue<>((a, b) -> a.frequency - b.frequency);for (int i = 0; i < data.length; i++) {minHeap.add(new Node(data[i], frequency[i]));}while (minHeap.size() > 1) {Node x = minHeap.poll();Node y = minHeap.poll();Node f = new Node('\0', x.frequency + y.frequency);f.left = x;f.right = y;minHeap.add(f);}return minHeap.poll();}// 打印霍夫曼编码static void printCodes(Node root, String s) {if (root.left == null && root.right == null && Character.isLetter(root.data)) {System.out.println(root.data + ": " + s);return;}printCodes(root.left, s + "0");printCodes(root.right, s + "1");}public static void main(String[] args) {char data[] = {'a', 'b', 'c', 'd', 'e', 'f'};int frequency[] = {5, 9, 12, 13, 16, 45};Node root = buildHuffmanTree(data, frequency);printCodes(root, "");}
}

2. 活动选择问题(Activity Selection Problem)

描述
活动选择问题是一个经典的贪心算法问题,给定一系列活动,每个活动都有开始时间和结束时间,目标是选择最大数量的互不重叠的活动。

Java案例

import java.util.Arrays;public class ActivitySelection {public static void selectActivities(int start[], int end[]) {Arrays.sort(end); // 按结束时间排序int i = 0, activities = 0;for (int j = 1; j < end.length; j++) {if (start[i] < end[j]) { // 如果当前活动的开始时间小于前一个活动的结束时间activities++;i = j; // 更新当前活动的索引}}System.out.println("Total activities selected: " + activities);}public static void main(String[] args) {int start[] = {1, 3, 0, 5, 8, 5};int end[] = {2, 4, 6, 7, 9, 9};selectActivities(start, end);}
}

3. 硬币找零问题(Coin Change Problem)

描述
硬币找零问题是一个典型的贪心算法问题,给定不同面额的硬币和一个总金额,目标是使用最少数量的硬币凑成总金额。

Java案例

public class CoinChange {public static int coinChange(int[] coins, int amount) {int[] dp = new int[amount + 1];Arrays.fill(dp, amount + 1); // 初始化为最大值dp[0] = 0; // 0元需要0个硬币for (int i = 1; i <= amount; i++) {for (int coin : coins) {if (i >= coin && dp[i - coin] != amount + 1) {dp[i] = Math.min(dp[i], dp[i - coin] + 1);}}}return dp[amount] > amount ? -1 : dp[amount];}public static void main(String[] args) {int[] coins = {1, 2, 5};int amount = 11;int result = coinChange(coins, amount);if (result != -1) {System.out.println("Minimum number of coins required: " + result);} else {System.out.println("Not possible to make the given amount");}}
}

这些案例展示了贪心算法在不同问题中的应用,包括霍夫曼编码、活动选择问题和硬币找零问题。贪心算法通过在每一步选择局部最优解来寻找全局最优解。

🌐 霍夫曼编码和哈夫曼编码有什么区别?

霍夫曼编码(Huffman Coding)和哈夫曼编码(Huffman Coding)实际上是同一个概念,只是翻译名称上的不同。在中文文献和技术社区中,这两种叫法都被广泛使用,但它们指的是同一种编码方法。

霍夫曼编码是一种广泛使用的无损数据压缩算法,由David A. Huffman在1952年发明。它是一种贪心算法,通过构建一个二叉树(霍夫曼树)来为输入字符分配可变长度的编码。树的叶子节点代表输入字符,而树的权重表示字符出现的频率。构建树的过程中,总是将两个权重最小的节点合并,直到构建出完整的霍夫曼树。然后,通过遍历树来为每个字符分配一个唯一的二进制编码,频率高的字符会被分配较短的编码,而频率低的字符则会被分配较长的编码。

因此,当你看到“霍夫曼编码”和“哈夫曼编码”时,可以认为它们是同一个算法的不同叫法。在英文中,这个算法统一被称为“Huffman Coding”。
在这里插入图片描述

🤔 霍夫曼编码在哪些场景下应用效果最好?

霍夫曼编码(Huffman Coding)在以下场景下应用效果最好:

  1. 文件压缩
    霍夫曼编码广泛应用于文件压缩领域,特别是在存储文件时,可以通过压缩来节省磁盘空间。虽然文件压缩后需要解压缩才能使用,但这通常是一次性的操作,因此空间和时间的权衡是可接受的。例如,在文件系统中存储不常使用的文件时,使用霍夫曼编码进行压缩可以显著减少存储空间的需求。

  2. 数据通信
    在数据通信领域,霍夫曼编码可以减少通信和I/O开销,特别是在高速流处理中。压缩原始模拟数据并在后处理前解压缩可以显著提高工作效率。

  3. 图像和视频压缩
    霍夫曼编码是许多图像和视频压缩标准的一部分,如JPEG。它用于对图像和视频数据进行无损压缩,是这些应用中不可或缺的一部分。

  4. 大规模科学数据集
    霍夫曼编码也被广泛用于压缩大型科学数据集,这些数据集对数据保真度有很高的要求。它在这些应用中表现出色,因为它可以有效地压缩数据,同时保持高数据保真度。

  5. 文本编码
    霍夫曼编码用于文本编码,特别是在不同字符使用频率差异较大的情况下。它通过为更频繁出现的字符分配较短的编码来实现空间效率,这在英语文档等文本中尤其有效,因为不同字母的使用频率差异很大。

  6. 通用无损压缩软件或库
    霍夫曼编码是许多通用无损压缩软件或库(如GZIP、Zstd和Blosc)中的关键步骤,它提供了一种有效的熵编码算法。

  7. 错误有界损失压缩
    在一些需要错误有界损失压缩的应用中,霍夫曼编码也被广泛使用,例如SZ和MGARD压缩器,这些压缩器在压缩大数据集时非常有效。

综上所述,霍夫曼编码在需要有效压缩数据以节省空间或减少传输时间的场景中效果最好,尤其是在字符使用频率不均的文本数据、图像和视频数据以及大规模科学数据集的压缩中。

📈 霍夫曼编码在减少网络带宽方面有哪些优势?

霍夫曼编码在减少网络带宽方面的优势主要体现在以下几个方面:

  1. 高效压缩
    霍夫曼编码为每个字符分配一个基于其出现频率的变长编码,高频字符使用较短的编码,低频字符使用较长的编码。这种优化可以显著减少数据的整体大小,从而减少网络传输所需的带宽。

  2. 适应性
    霍夫曼编码是自适应的,可以根据数据的实际内容动态构建最优编码树。这意味着它能够针对特定的数据集进行优化,与固定编码方案相比,能够更有效地压缩数据。

  3. 无损压缩
    霍夫曼编码是一种无损压缩算法,这意味着压缩和解压后的数据与原始数据完全相同。这对于必须确保数据完整性的应用场景(如文件传输、视频流等)至关重要。

  4. 广泛支持
    霍夫曼编码被广泛支持和实现在各种压缩工具和协议中,如HTTP压缩、ZIP文件格式、JPEG图像压缩等。这种广泛的支持意味着它可以很容易地集成到现有的网络通信系统中。

  5. 减少延迟
    通过减少数据的大小,霍夫曼编码可以减少数据在网络上的传输时间,从而降低延迟,特别是在高延迟网络环境中。

  6. 节省成本
    减少网络带宽的使用可以直接降低网络服务提供商的成本,尤其是在需要支付流量费用的场景下,如移动数据服务。

  7. 提高吞吐量
    在带宽受限的网络中,更有效地压缩数据可以提高网络的吞吐量,允许在同一带宽内传输更多的数据。

  8. 支持流式传输
    霍夫曼编码支持流式压缩和解压,这意味着数据可以边传输边解压,而不需要等待整个文件传输完成,这对于流媒体应用(如视频会议和在线视频流)非常有用。

  9. 易于实现
    霍夫曼编码算法相对简单,易于实现,并且有许多现成的库和工具可供使用,这使得它能够快速部署在各种网络应用中。

  10. 可扩展性
    霍夫曼编码可以应用于不同规模的数据,从小型文本文件到大型视频文件,都能有效地减少所需的网络带宽。

综上所述,霍夫曼编码在减少网络带宽方面的优势使其成为网络数据传输中不可或缺的技术之一。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

推荐一款专业电脑护眼工具:CareUEyes Pro

CareUEyes Pro是一款非常好用的专业电脑护眼工具&#xff0c;软件小巧&#xff0c;界面简单&#xff0c;它可以自动过滤电脑屏幕的蓝光&#xff0c;让屏幕显示更加的不伤眼&#xff0c;更加舒适&#xff0c;有效保护你的眼睛&#xff0c;可以自定义调节屏幕的色调&#xff0c;从…

记录一下在原有的接口中增加文件上传☞@RequestPart

首先&#xff0c;咱声明一下&#xff1a; RequestBody和 MultipartFile 不可以 同时使用&#xff01;&#xff01;&#xff01; 因为这两者预期的请求内容类型不同。RequestBody 预期请求的 Content-Type 是 application/json 或 application/xml&#xff0c;而 MultipartFile …

国标GB28181视频平台EasyCVR视频融合平台H.265/H.264转码业务流程

在当今数字化、网络化的视频监控领域&#xff0c;大中型项目对于视频监控管理平台的需求日益增长&#xff0c;特别是在跨区域、多设备、高并发的复杂环境中。EasyCVR视频监控汇聚管理平台正是为了满足这些需求而设计的&#xff0c;它不仅提供了全面的管理功能&#xff0c;还支持…

JavaSrcipt 函数高级

一 原型与原型链 prototype 每个函数都有一个prototype属性, 它默认指向一个Object空对象(即称为: 原型对象或者显示原型) 原型对象prototype中有一个属性constructor, 它指向函数对象 function a(){}console.log(typeof a,typeof Date)console.log(a.prototype, Date.prot…

蓝桥杯每日真题 - 第17天

题目&#xff1a;&#xff08;最大数字&#xff09; 题目描述&#xff08;13届 C&C B组D题&#xff09; 题目分析&#xff1a; 操作规则&#xff1a; 1号操作&#xff1a;将数字加1&#xff08;如果该数字为9&#xff0c;变为0&#xff09;。 2号操作&#xff1a;将数字…

sysbench压测DM的高可用切换测试

一、配置集群 1. 配置svc.conf [rootlocalhost dm]# cat /etc/dm_svc.conf TIME_ZONE(480) LANGUAGE(CN)DM(192.168.112.139:5236,192.168.112.140:5236) [DM] LOGIN_MODE(1) SWITCH_TIME(300) SWITCH_INTERVAL(200)二、编译sysbench 2.1 配置环境变量 [dmdba~]# vi ~/.bas…

解决vue-pdf的签章不显示问题

在使用vue-pdf 4.3.0时发现上传一般的普通pdf正常预览&#xff0c;但是上传带有红头文件的和和特殊字体的pdf无法正常内容显示&#xff0c;文字丢失问题。 1、查看控制台报错信息 2、缺少字体原因 getNumPages(url) {var loadingTask pdf.createLoadingTask({url: url,//引入…

免费开源!DBdoctor推出开源版系统诊断工具systool

​前言 在开发和运维过程中&#xff0c;经常会遇到难以定位的应用问题&#xff0c;我们通常需要借助Linux系统资源监控工具来辅助诊断。然而&#xff0c;系统的IO、网络、CPU使用率以及文件句柄等信息通常需要通过多个独立的命令工具来获取。在没有部署如Prometheus这样的综合…

Redis基本的全局命令

在学习redis基本的全局命令之前呢&#xff0c;我们必须先进入redis-cli客户端才行。 如图&#xff1a; get和set get和set是redis两个最核心的命令。 get&#xff1a;根据key来获取value。 set&#xff1a;把key和value存储进去。 如set命令如图&#xff1a; 对于上述图中&…

招商蛇口|在低密园林里,开启生活的“任意门”

“最好的建筑是这样的&#xff0c;我们深处在其中,却不知道自然在哪里终了&#xff0c;艺术在哪里开始。” 凭借深耕西安10载的城市远见&#xff0c;以及建立在成功人居经验之上的敏锐洞察&#xff0c;招商蛇口将林语堂名言里的生活&#xff0c;变成了现实。 都市化越是加速&…

2024年亚太数学建模竞赛问题C宠物产业及相关产业发展分析与对策

随着人们消费理念的发展&#xff0c;随着经济的快速发展和人均收入的提高&#xff0c;宠物产业作为一个新兴产业在全球范围内逐渐积聚势头。1992年&#xff0c;中国小动物保护协会成立&#xff0c;随后1993年&#xff0c;皇家狗狗、玛氏等国际宠物品牌进入中国市场。随着“宠物…

嵌入式面试八股文(九)·FreeRTOS与Linux的区别与相同点、多进程与多线程的区别、为什么项目使用多线程

目录 1. FreeRTOS与Linux的区别与相同点 1.1 相同点 1.1.1 任务调度 1.1.2 多任务支持 1.1.3 内存管理 1.1.4 中断处理 1.1.5 同步机制 1.2 不同点 1.2.1 设计目标 1.2.2 实时性 1.2.3 内存管理 1.2.4 进程管理 1.2.5 多核支持 1.2.6 硬件支持 1.…

SpringBoot(8)-任务

目录 一、异步任务 二、定时任务 三、邮件任务 一、异步任务 使用场景&#xff1a;后端发送邮件需要时间&#xff0c;前端若响应不动会导致体验感不佳&#xff0c;一般会采用多线程的方式去处理这些任务&#xff0c;但每次都需要自己去手动编写多线程来实现 1、编写servic…

css:感觉稍微高级一点的布局

精灵图 有时候我们下载网页里的小元素图片的时候&#xff0c;就会一下子下载一大张&#xff0c;这就是精灵图&#xff0c;也叫雪碧图&#xff08;sprites&#xff09; 一个网页由很多图像作为修饰&#xff0c;当网页中图像过多时&#xff0c;服务器会频繁地解释和发送氢气图片…

docker安装zabbix +grafana

安装zabbix grafana 1、部署 mkdir -p /opt/zabbix/{data,backups}mkdir -p /opt/grafanasudo chown -R 472:472 /opt/grafanasudo chmod -R 755 /opt/grafanacat > docker-compose.yml <<-EOF version: 3.3services:mysql-server:image: mysql:8.1container_name: m…

什么是Hadoop

Hadoop 介绍 Hadoop 是由 Apache 开发的开源框架&#xff0c;用于处理分布式环境中的海量数据。Hadoop 使用 Java 编写&#xff0c;通过简单的编程模型允许在集群中进行大规模数据集的存储和计算。它具备高可靠性、容错性和扩展性。 分布式存储&#xff1a;Hadoop 支持跨集群…

六大核心应用场景,解锁AI检测系统的智能安全之道

AI检测系统基于深度学习、计算机视觉和多模态数据融合技术&#xff0c;广泛应用于工业、能源、制造等高风险作业领域&#xff0c;旨在实现作业安全、流程规范和效率提升的智能化管理。以下是系统主要应用场景的概述&#xff1a; 1. 高风险作业安全监控 应用场景&#xff1a;高压…

Verilog HDL可综合与不可综合语句

目录 什么是逻辑综合 可综合语句 不可综合语句 逻辑综合建模建议 综合流程 什么是逻辑综合 所谓逻辑综合就是在标准单元库和特定的设计约束的基础上&#xff0c;把设计的高层次描述转换成优化的门级网表的过程。 标准单元库&#xff08;工艺库&#xff09;可以包含简单的…

SpringBoot中设置超时30分钟自动删除元素的List和Map

简介 在 Spring Boot 中&#xff0c;你可以使用多种方法来实现自动删除超时元素的 List 或 Map。以下是两种常见的方式&#xff1a; 如果你需要简单的功能并且不介意引入外部依赖&#xff0c;可以选择 Guava Cache。如果你想要更灵活的控制&#xff0c;使用 Spring 的调度功能…

@RequestBody、@Data、@Validated、@Pattern(regexp=“?“)(复习)

目录 一、注解RequestBody。 二、注解Data。 三、注解Validated、Pattern(regexp"?")。 1、完成实体参数&#xff08;对象属性&#xff09;校验。 2、NotNull、NotEmpty、Email。 一、注解RequestBody。 &#xff08;如&#xff1a;JSON格式的数据——>Java对象&…