- 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/
我创建了以下 sub 来简单地说明问题。我将事件工作表的范围 A2:E10 分配给范围变量。然后,对于另一个范围变量,我将这个范围的子范围,单元格 (1, 1) 分配给 (3, 3)。 我原以为这将包
我使用正则表达式来搜索以下属性返回的纯文本: namespace Microsoft.Office.Interop.Word { public class Range {
我正在开发一个宏来突出显示某些行/单元格以供进一步审查。一些值/空白将以红色突出显示,其他以橙色突出显示,而整行应为黄色。我从上一个问题中得到了一些帮助,并添加了更多细节,它工作得几乎完美,但我被困在
这个问题在这里已经有了答案: What is the difference between range and xrange functions in Python 2.X? (28 个答案) 关闭
我在尝试运行脚本时遇到这个奇怪的错误,代码似乎是正确的,但似乎 python (3) 不喜欢这部分: def function(x): if int
我正在编写一种算法,将一些数据写入提供的输出范围(问题的初始文本包括具体细节,这将评论中的讨论转向了错误的方向)。我希望它在 API 中尽可能接近标准库中的其他范围算法。 我查看了 std::rang
这按预期工作: #include #include int main() { auto chunklist = ranges::views::ints(1, 13) | ranges::vie
我这里有一个字符串,我正在尝试对其进行子字符串化。 let desc = "Hello world. Hello World." var stringRange = 1..' 的值转换为预期的参数类型
我有一个高级搜索功能,可以根据日期和时间查询记录。我想返回日期时间范围内的所有记录,然后从该范围内返回我想将结果缩小到一个小时范围(例如 2012 年 5 月 1 日 - 2012 年 5 月 7 日
Go 中的 range 函数和 range 关键字有什么区别? func main(){ s := []int{10, 20, 30, 40, 50, 60, 70, 80, 90}
如果我有一个范围,如何将其拆分为一系列连续的子范围,其中指定了子范围(存储桶)的数量?如果没有足够的元素,则应省略空桶。 例如: splitRange(1 to 6, 3) == Seq(Range(
我正在开发 VSTO Excel 项目,但在管理 Range 对象时遇到一些问题。 实际上,我需要知道当前选定的范围是否与我存储在列表中的另一个范围重叠。所以基本上,我有 2 个 Range 实例,我
在即将推出的 C++20 系列中,将有 range concept具有以下定义: template concept range = __RangeImpl; // exposition-only de
希望有人能回答我的问题。我在 VHDL 代码中遇到了这个命令,但不确定它到底做了什么。有人可以澄清以下内容吗? if ( element1 = (element1'range => '0')) the
可以将范围嵌套在范围中吗?使用范围内的变量?因为我想取得一些效果。为了说明这个问题,我有以下伪代码: for i in range(str(2**i) for i in range(1,2)):
我想在 2 个日期之间创建一个范围,并且我的范围字段有时间 damage_list = Damage.objects.filter(entry_date__range=(fdate, tdate))
在下面的代码中 #include #include #include int main() { std::unordered_mapm; m["1"]=1; m["2"]=2
我试图为我的电子表格做一个简单的循环,它循环遍历一个范围并检查该行是否为空,如果不是,则循环遍历一系列列并检查它们是否为空,如果是则它设置一个消息。 问题是每次它通过循环 ro.value 和 col
我在将一个工作簿范围中的值分配给当前工作簿中的某个范围时遇到问题。当我使用 Range("A1:C1") 分配我的范围时,此代码工作正常,但是当我使用 Range(Cells(1,1),Cells(1
我改写了原来的问题。 Sub s() Dim r As Range Set r = ActiveSheet.Range("B2:D5") Debug.Print r.Rows.Count
我是一名优秀的程序员,十分优秀!