- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在网上(在 King 的网站上)看一个挑战,虽然我理解它背后的总体思路,但我有点迷路了——也许措辞有点不对?这是问题所在,我将在下面说明我不明白的地方:
Error correcting codes are used in a wide variety of applications ranging from satellite communication to music CDs. The idea is to encode a binary string of length k as a binary string of length n>k, called a codeword such that even if some bit(s) of the encoding are corrupted (if you scratch on your CD for instance), the original k-bit string can still be recovered. There are three important parameters associated with an error correcting code: the length of codewords (n), the dimension (k) which is the length of the unencoded strings, and finally the minimum distance (d) of the code. Distance between two codewords is measured as hamming distance, i.e., the number of positions in which the codewords differ: 0010 and 0100 are at distance 2. The minimum distance of the code is the distance between the two different codewords that are closest to each other. Linear codes are a simple type of error correcting codes with several nice properties. One of them being that the minmum distance is the smallest distance any non-zero codeword has to the zero codeword (the codeword consisting of n zeros always belongs to a linear code of length n). Another nice property of linear codes of length n and dimension k is that they can be described by an n×k generator matrix of zeros and ones. Encoding a k-bit string is done by viewing it as a column vector and multiplying it by the generator matrix. The example below shows a generator matrix and how the string 1001 is encoded. graph.png Matrix multiplication is done as usual except that additon is done modulo 2 (i.e., 0+1=1+0=1 and 0+0=1+1=0). The set of codewords of this code is then simply all vectors that can be obtained by encoding all k-bit strings in this way. Write a program to calculate the minimum distance for several linear error correcting codes of length at most 30 and dimension at most 15. Each code will be given as a generator matrix. Input You will be given several generator matrices as input. The first line contains an integer T indicating the number of test cases. The first line of each test case gives the parameters n and k where 1≤n≤30, 1≤k≤15 and n > k, as two integers separated by a single space. The following n lines describe a generator matrix. Each line is a row of the matrix and has k space separated entries that are 0 or 1. Output For each generator matrix output a single line with the minimum distance of the corresponding linear code.
示例输入 1
2
7 4
1 0 0 0
0 1 0 0
0 0 1 0
0 0 0 1
0 1 1 1
1 0 1 1
1 1 0 1
3 2
1 1
0 0
1 1
示例输出 1
3
0
现在我的假设是问题是问“写一个程序,可以接受矩阵形式的线性代码,并说出与全零代码字的最小距离是多少”我只是不明白为什么有一个 3第一个输入的输出和第二个输入的 0?
很困惑。
有什么想法吗?
最佳答案
第一个例子:
Input binary string: 1000
Resulting code: 1100001
Hamming distance to zero codeword 0000000: 3
第二个例子:
Input binary string: 11
Resulting code: 000
Hamming distance to zero codeword 000: 0
您的目标是找到有效非零代码字(可以从一些非零 k 位输入字符串中生成)到零代码字的汉明距离最小(换句话说 - 最小二进制表示的数量)并返回该距离。
希望对你有帮助,问题描述确实有点难看
编辑。我在第一个例子中打错了字。实际输入应该是 1000 而不是 0001。此外,可能不清楚输入字符串到底是什么以及代码字是如何计算的。我们来看第一个示例。
Input binary string: 1000
一般来说,这个二进制字符串不是生成矩阵的一部分。它只是所有可能的非零 4 位字符串之一。让我们将它乘以生成矩阵:
(1 0 0 0) * (1 0 0 0) = 1
(0 1 0 0) * (1 0 0 0) = 0
(0 0 1 0) * (1 0 0 0) = 0
(0 0 0 1) * (1 0 0 0) = 0
(0 1 1 1) * (1 0 0 0) = 0
(1 0 1 1) * (1 0 0 0) = 1
(1 1 0 1) * (1 0 0 0) = 1
找到产生“最小”码字的输入的一种方法是迭代所有 2^k-1 个非零 k 位字符串并为它们中的每一个计算码字。这是 k <= 15 的可行解。
第一个测试用例 0011 的另一个示例(可能有多个输入产生“最小”输出):
(1 0 0 0) * (0 0 1 1) = 0
(0 1 0 0) * (0 0 1 1) = 0
(0 0 1 0) * (0 0 1 1) = 1
(0 0 0 1) * (0 0 1 1) = 1
(0 1 1 1) * (0 0 1 1) = 2 = 0 (mod 2)
(1 0 1 1) * (0 0 1 1) = 2 = 0 (mod 2)
(1 1 0 1) * (0 0 1 1) = 1
结果代码 0011001 与零代码字的汉明距离也为 3。没有 4 位字符串的代码在二进制表示中少于 3 个。这就是为什么第一个测试用例的答案是 3。
关于algorithm - 纠错码和最小距离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27909433/
对于允许银行/电汇的支付系统,我需要将支付与相应的用户帐户可靠地关联起来。为此,用户应在与其帐户关联的转账中包含引用号。 我想用内置冗余(额外符号)生成这个数字,以便我可以检测和纠正最多 N 个以下(
我需要对短消息(100 到 200 位之间)使用纠错技术。可用于添加冗余位的空间被限制在 20-50%。 我将不得不在 C/C++ 中实现编码和解码。所以它需要是开源的或者足够容易编程。 (我过去有过
是否有针对 Java 的 ECC(纠错代码)库(例如 Reed-Solomon)的众所周知的实现,它具有友好的开源许可(非 GPL)? 最佳答案 zxing Apache 许可证(不确定这是否符合您对
我是一名优秀的程序员,十分优秀!