- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
作为每天练习围棋的练习,我每天都在 r/dailyprogrammer 上尝试一项日常挑战。
目前,我正在实现中级挑战 #362 ( https://www.reddit.com/r/dailyprogrammer/comments/8n8tog/20180530_challenge_362_intermediate_route/ ),这是一个简单的加密/解密挑战。
所以在我的方法中,我有一个基本结构来表示输入:
type Vector struct {
x, y int
}
type Input struct {
text string
vector Vector
method string
}
以及挑战输入的一部分结构:
inputs := []Input{
{"WE ARE DISCOVERED. FLEE AT ONCE", Vector{9, 3}, "clockwise"},
{"why is this professor so boring omg", Vector{6, 5}, "counter-clockwise"},
{"Solving challenges on r/dailyprogrammer is so much fun!!", Vector{8, 6}, "counter-clockwise"},
{"For lunch let's have peanut-butter and bologna sandwiches", Vector{4, 12}, "clockwise"},
{"I've even witnessed a grown man satisfy a camel", Vector{9, 5}, "clockwise"},
{"Why does it say paper jam when there is no paper jam?", Vector{3, 14}, "counter-clockwise"},
}
到目前为止,还不错。
我有一个函数来简化挑战中概述的输入字符串(即一个函数删除所有标点符号并用“X”填充字符串以达到所需网格的长度)。
之后,我将字符串输入此函数,以创建矩阵网格:
func makeGrid(s string, v Vector) [][]byte {
g := make([][]byte, v.y, v.x)
for k, c := range s {
g[k/v.x] = append(g[k/v.x], byte(c))
}
return g
}
因此对于第一个输入,例如,运行程序将产生如下网格(为了便于阅读,下面包含字符串而不是字节):
[[W E A R E D I S C]
[O V E R E D F L E]
[E A T O N C E X X]]
但是,当程序到达这个输入时:
{"For lunch let's have peanut-butter and bologna sandwiches", Vector{4, 12}, "clockwise"},
抛出以下错误:
panic: runtime error: makeslice: cap out of range
此输入相同:
{"Why does it say paper jam when there is no paper jam?", Vector{3, 14}, "counter-clockwise"},
我完全明白为什么错误发生在运行时而不是编译时,因为编译器无法在编译期间知道网格的大小,所以 panic 只能发生在运行时。
我不明白的是我反转了输入中的向量:
{"For lunch let's have peanut-butter and bologna sandwiches", Vector{12, 4}, "clockwise"},
{"Why does it say paper jam when there is no paper jam?", Vector{14, 3}, "counter-clockwise"},
错误不再发生。程序运行良好。
它只发生在向量中的 x 值小于 y 值的情况下。
调试并跟踪代码,我不太明白为什么有很多短行的网格会抛出错误,而长行很少的网格不会。
这里似乎还有其他一些可能相关的答案,但我看不出应该如何修改我的方法以避免错误。
有什么想法吗?
最佳答案
根据 Tim Cooper 的回复,这是一个简单的修复。
只是更改了 make 语句以正确使用它:
func makeGrid(s string, v Vector) [][]byte {
g := make([][]byte, v.y)
for k, c := range s {
g[k/v.x] = append(g[k/v.x], byte(c))
}
return g
}
现在工作正常。
关于go - panic : runtime error: makeslice: cap out of range,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50789279/
使用这个通用元组类 public class Pair { private final T1 first; private final T2 second; public Pair(T1
我想不出执行此操作的递归算法。我的尝试是: void capValue(Node node) { if (node == null) return if (node.e
较新版本的 docker(我认为是 1.2 及更高版本)具有 --cap-add 功能。 这提供了对特性功能的细粒度控制,而无需使用 --privileged=true 打开所有内容。 我用谷歌搜索过
我开始使用 vim,我想重新映射一些键。有谁知道在 Lubuntu 中最简单的方法是什么。 谢谢 最佳答案 Caps Lock 键不能在 Vim 中映射,因为它不会自己生成键码。您可以在操作系统级别重
这是我的代码。 import java.util.stream.Stream; import java.util.List; import java.util.ArrayList; import ja
我想在 PyCharm 中使用 CapsLock-u 和 CapsLock-n 在代码和运行/终端之间切换。 在我的键盘上 u位于顶部,n在底部,这给了我一个很好的内存方法。 我不知道如何像这样配置我
我有一个值都是大写的对象,我想要 f.label帮助将其打印为全部大写 - 无需进行 CSS 转换。 现在,如果我有字符串 AAPL在我的对象中,f.label吐出来为 Aapl . 我不想使用 CS
我是电容器的新手,正在开发一个应用程序,我正在对代码进行更改并运行 ionic 构建 npx上限副本 npx盖帽开安卓 并且还推荐使用 npx cap sync代npx cap copy . 两者之间
print("Hello and welcome to your address book this program uses surnames or D.O.B to find people in
我在编写一些代码时遇到了一些让我烦恼的事情。我在下面的代码示例中收集了这两个示例。 cls1 行使用 lambda 表达式但不编译,而 cls2 行使用方法引用并编译。我知道如果我使用非泛型对象,我不
我一直在阅读有关名为Starcounter的数据库的信息。它声称可以处理“ NoSql”数据库只能处理的负载而不会降低一致性。据我了解CAP定理,如果保持一致性,则会失去可用性或分区容限。那么什么使S
分布式系统如何保持一致和可用-CA。因为当分区发生时,CA是不可能的。如果我们说不会发生分区,那么只有它们是CA,那么如果分区不会发生,那么所有CP或AP系统也将是CA。 最佳答案 不可以 如常提到的
我是 java 编程的初学者,并且在弄清楚如何限制代码中的金额时遇到问题。 我的代码有一个问题,该代码由 if-else if 语句组成,这更多的是如何限制奖金最高金额的问题。我希望我的奖金最高金额为
说到nosql分布式数据库系统,我们都知道它们都属于CAP定理的三取二。对于网络故障和节点故障不可避免的分布式集群,分区容忍是必要的,因此我们只能从可用性和一致性中选择一个。所以它基本上是 CP 或
python如何为视频制作一个简单的帽子。 Ideia:为 9 个均匀放置(在时间轴上)时间拍摄 9 个快照,然后在 JGP 中置换 我应该怎么做? PIL 是唯一的方法吗? (做我想做的事情并不容易
这个问题在这里已经有了答案: Is working past the end of a slice idiomatic? (2 个答案) 关闭 6 年前。 下面的go代码: var numbers4
我有一个 Silverlight 应用程序,它有两个不同的 XAP——一个由 HTML 页面静态加载的 InitialXAP 和一个从初始 XAP 中的代码加载的 DynamicXAP。 Dynami
In the wikipedia article on CAP Theorem( https://en.wikipedia.org/wiki/CAP_theorem ), it states (bol
在CAP定理中,Redis被指定为缺乏可用性(具有分区容错性和一致性)的数据库。 但是在很多地方,Redis 被认为是一种高可用的键值存储。 什么是对的?如果您能提供深入的答案,我将不胜感激。 最佳答
我被告知我必须放弃大型分布式系统中的事务保证,因为 CAP theorem说我不能拥有它。 我认为这是错误的,原因如下: 互联网路由非常可靠。 CAP 定理仅适用于两组事件机器无法通信的网络分区。 几
我是一名优秀的程序员,十分优秀!