- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
假设您有一个由一堆固定大小的 block 组成的大文件。这些 block 中的每一个都包含一些可变大小的记录。每个记录必须完全适合一个 block ,然后根据定义,这些记录永远不会大于一个完整的 block 。随着时间的推移,随着记录从这个“数据库”进出,记录会被添加到这些 block 中或从这些 block 中删除。
在某些时候,尤其是在可能有很多记录被添加到数据库中并且有一些被删除之后 - 许多 block 可能最终只被部分填充。
有什么好的算法可以通过更好地填充部分填充 block 来打乱该数据库中的记录以压缩文件末尾不必要的 block ?
算法要求:
最佳答案
这听起来像是 bin packing problem 的变体,但是您已经有了想要改进的劣质分配。因此,我建议查看对装箱问题成功的方法的变体。
首先,您可能希望通过定义您认为“足够满”( block 足够满以至于您不想触摸它)以及“太空”(其中一个 block 有太多的空白空间,它必须有更多的记录添加到它)。然后,您可以将所有 block 分类为足够满、太空或部分满(那些既不够满也不太空)。然后,您将问题重新定义为如何通过创建尽可能多的足够满的 block 来消除所有太空的 block ,同时尽量减少部分满的 block 的数量。
您还需要弄清楚什么更重要:将记录放入尽可能少的 block 中,或者充分打包它们但读取和写入的 block 数量最少。
我的方法是对所有 block 进行初始传递,将它们全部分类为上面定义的三个类别之一。对于每个 block ,您还需要跟踪其中的可用空间,对于太空的 block ,您需要一个包含所有记录及其大小的列表。然后,从太空的 block 中最大的记录开始,将它们移动到部分满的 block 中。如果你想最小化读取和写入,将它们移动到你当前内存中的任何 block 中。如果您想最大程度地减少浪费的空间,请找到空白空间最少的 block ,该 block 仍将保留记录,必要时读入该 block 。如果没有 block 将保留记录,则创建一个新 block 。如果内存中的 block 达到“足够满”的阈值,则将其写出。重复直到部分填充 block 中的所有记录都已放置。
我跳过了很多细节,但这应该能让您有所了解。注意装箱问题是NP-hard ,这意味着对于实际应用,您需要决定什么对您最重要,因此您可以选择一种能够在合理时间内为您提供近似最佳解决方案的方法。
关于algorithm - 什么是压缩被阻止文件中记录的好算法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/130227/
我有点想做 the reverse of this. 我不想解压缩并将收集文件添加到 S3 应用户要求: 生成一堆xml文件 使用一些图像(托管在 s3 上的预先存在的图像)压缩 xml 文件 下载
将此添加到域的虚拟主机后 AddOutputFilterByType DEFLATE application/javascript text/javascript text/css 响应头不包含任何内
在 Apache Im 中,通过将以下内容添加到我的 .htaccess 文件来启用输出压缩: # compress text, html, javascript, css, xml: AddOutp
是否可以以压缩格式将请求数据从浏览器发送到服务器? 如果是,我们该怎么做? 最佳答案 压缩从浏览器发送到服务器的数据是不受 native 支持 在浏览器中。 您必须找到一种解决方法,使用客户端语言(可
我正在寻找可以压缩JavaScript源代码的工具。我发现一些网络工具只能删除空格字符?但也许存在更好的工具,可以压缩用户的函数名称、字段名称、删除未使用的字段等。 最佳答案 经常用来压缩JS代码的工
使用赛马博彩场景,假设我有许多单独的投注来预测比赛的前 4 名选手 (superfecta)。 赌注如下... 1/2/3/4 1/2/3/5 1/2/4/3 1/2/4/5 1/2/5/3
我是一名实习生,被要求对 SQL 2008 数据压缩进行一些研究。我们想将 Outlook 电子邮件的几个部分存储在一个表中。问题是我们想将整个电子邮件正文存储在一个字段中,然后又想压缩它。使用 Ch
我目前有一个系统,用户可以在其中上传 MP4 文件,并且可以在移动设备上下载该文件。但有时,这些视频的大小超过 5MB,在我国,大多数人使用 2G。因此,下载大型视频通常需要 15-20 分钟。 有什
假设我有一个带有类型列的简单文档表: Documents Id Type 1 A 2 A 3 B 4 C 5 C 6 A 7 A 8 A 9 B 10 C 用户
我有一个较大字符串中的(子)字符串位置的 data.frame。数据包含(子)字符串的开头及其长度。可以很容易地计算出(子)字符串的结束位置。 data1 start length end #>
我想知道是否 文件加密算法可以设计成它也可以执行文件压缩的事件(任何活生生的例子?)。 我也可以将它集成到移动短信服务中,我的意思是短信吗? 另外我想知道二进制文件...如果纯文本文件以二进制编码
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我们有几个具有大量 JavaScript 的 Java 项目,目前我们使用的是旧版本的 YUICompressor (2.4.2)。然而,我在这篇博文中发现 YUICompressor 正在 depr
从之前关于尝试提高网站性能的文章中,我一直在研究 HTTP 压缩。我读过有关在 IIS 中设置它的信息,但它似乎是所有 IIS 应用程序池的全局事物,我可能不允许这样做,因为还有另一个站点在其上运行。
我有一个 REST 服务,它返回一大块 XML,大约值(value) 150k。 例如http://xmlservice.com/services/RestService.svc/GetLargeXM
我正在尝试获取一个简单的 UglifyJS (v2.3.6) 示例来处理压缩。 具体来说,“未使用”选项,如果从未使用过,变量和函数将被删除。 这是我在命令行上的尝试: echo "function
我正在开发一个项目,如果我的磁盘出现问题,我将在使用 ZLIB 压缩内存块后将其发送到另一个磁盘。然后我计划下载该转储并用于进一步调试。这种压缩和上传将一次完成一个 block - 比如说 1024
LZW 压缩算法在压缩后增加了位大小: 这是压缩函数的代码: // compression void compress(FILE *inputFile, FILE *outputFile) {
我的问题与如何在 3D 地形上存储大量信息有关。这些信息应该是 secret 的,因为它们非常庞大,也应该被压缩。我选择了文件存储,现在我想知道将对象数据加密/压缩(或压缩/加密)到文件的最佳做法。
我使用以下代码来压缩我的文件并且效果很好,但我只想压缩子文件夹而不是在压缩文件中显示树的根。 public boolean zipFileAtPath(String sourcePath, Strin
我是一名优秀的程序员,十分优秀!