- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的应用程序是多项选择测试,其中每个问题的响应结果都是一个 4 字母字符串“eg”GTAC 或 ATGC 或 CATG 等。总是只有 24 个问题。所以最后的结果是这样的
GTAC CATG TACG GACT GTAC CATG TACG GACT GTAC CATG TACG GACT GTAC CATG TACG GACT GTAC CATG TACG GACT GTAC CATG TACG GACT
因此每个响应有 4!=24 种可能性。我可以将每种可能性映射到一个字母 A-X,这会将其缩减为 24 个字母大小的字符串,但我相信一定有一种简单的方法可以将其缩减为大约 6 个字符。
结果将通过 http 请求发送,因此我需要将其压缩为字母数字字符串,如 base64,但不一定是 base64。
数据只是一个像上面那样的字符串,或者我可以把它放在任何格式来匹配你的循环。我正在寻找类似 10 行压缩算法的东西。我将在 javascript 中压缩并在 php 中解压缩。
最佳答案
您可以将其最小化为 24 lg(24) ~= 111 位或 14 字节。然后要将其编码为 84 个 URL 可接受的字符,您必须将其扩展到至少 18 个字符。 24 lg(24)/lg(84) = 17.2。假设 24 个答案中的每一个都可能有 24 个选择,那么就没有办法让它少于 18 个字符。当然不是六个。
你用 24 个字符编码的方案对我来说似乎很好。 18 比 24 的增益似乎不值得任何额外的复杂性。但是,如果您必须...
将答案分成八组,每组三组。对于每组三个,将其视为一个三位数的 24 进制数,范围为 0..13823。这将适合 14 位。其中八个是 14 字节或 112 位。
现在一次拉出 19 位。将有六组,最后一组只有 17 位。对于每组 19,将其编码为一个三位数的 81 基数,发出三个 URL 安全字符。 813> 219。从 84 个 URL 安全字符中选择您最喜欢的 81 个字符。
现在您有 18 个字符代表 24 个答案。除非您没有告诉我们的答案有其他一些限制,否则您不能做得更好。
关于javascript - 用于压缩类 DNA 字符串的简单紧凑代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20527243/
问题:用任何语言编写一个程序,给定一个字符串,生成一个与输入字符串的任何字谜匹配的正则表达式。对于所有大于某个长度 N 的正则表达式,正则表达式必须短于列出所有可能的字谜的“蛮力”解决方案,其中列出了
我正在尝试使用 html 和 css 生成一个简单的甘特图,我需要弄清楚如何使它紧凑,这意味着如果有可用的空白,该条应尝试适合前一行,同时保持相同的 x 距离。 上下文: X 轴是以月为单位的时间轴
我收到以下错误 (1/1) ErrorException compact(): Undefined variable: operator 这是我的代码行 $postsCat = Post::w
我正在使用 java 读取紧凑/截断的 PDF417 条形码,并且我有标准 PDF417 条形码的开始和结束模式的矩阵: Start Pattern = 81111113 (ending wit
我正在使用的当前 ListView 在文本上方和下方有额外的空间。我如何使它成为一个真正紧凑的? http://jsfiddle.net/qW6sP/8/
是否有办法“压缩”SQL 查询的结果? 结果如下: +----+-----------+----------+-----------+-------------+--------+ | ID | Fi
我目前在我的 Java 项目中使用 JSON(通过 gzip 压缩),其中我需要在磁盘上存储大量对象(数亿)。我每行有一个 JSON 对象,并且不允许在 JSON 对象中换行。这样我就可以逐行从磁盘流
R具有qr()函数,该函数使用LINPACK或LAPACK执行QR分解(以我的经验,后者快5%)。返回的主要对象是一个矩阵“ qr”,该矩阵包含在上三角矩阵R中(即R=qr[upper.tri(qr)
我希望开始 SQL 开发,因此决定用 Java 和 C# 实现一个使用基于 SQL 的数据库的应用程序,特别是它将是一个桌面应用程序,用于存储某些类型的数据通过数据库访问用户机器。 阅读此处发布的答案
我目前正在尝试解决一个奇怪的问题。我找不到太多相关信息。 简而言之: 当反序列化一个 xml 序列化对象时,我得到了一个正确对象类型的实例,但我只得到了对象内部的默认值。 长话短说: 序列化和反序列化
假设我需要一个包含许多重复元素的数组,如下所示: [3,3,3,3,3,8,8,8,8,5,5,5,5,5,5](所以这是五个 3,四个 8,和六个 5) 在 python 中,你可以像这样非常优雅地
这个问题在这里已经有了答案: Reverse the ordering of words in a string (48 个回答) 关闭 7 年前。 所以我正在尝试针对提示提出一个好的 C++ 解决
我是一名优秀的程序员,十分优秀!