这是在我运行最新的gcloud更新后开始的:
gcloud components update
Run Code Online (Sandbox Code Playgroud)
我曾经能够像我这样部署我的应用程序:
appcfg.py update app.yaml
Run Code Online (Sandbox Code Playgroud)
现在我得到:
appcfg.py: command not found
Run Code Online (Sandbox Code Playgroud)
是否有gcloud用于部署App Engine应用程序的新命令?
这是我最近遇到的一个有趣的小挑战.我将在下面提供我的答案,但我很想知道是否有更优雅或有效的解决方案.
描述了向我提出的要求:
这是一个测试数据集:
test_cases = [
# (unsorted list, sorted list)
(list('bca'), ['a', 'b', 'c']),
(list('CbA'), ['A', 'b', 'C']),
(list('r0B9a'), ['a', 'B', 'r', '0', '9']),
(['a2', '1a', '10a', 'a1', 'a100'], ['a1', 'a2', 'a100', '1a', '10a']),
(['GAM', 'alp2', 'ALP11', '1', 'alp100', 'alp10', '100', 'alp1', '2'],
['alp1', 'alp2', 'alp10', 'ALP11', 'alp100', 'GAM', '1', '2', '100']),
(list('ra0b9A'), ['A', 'a', 'b', 'r', '0', '9']),
(['Abc', 'abc', 'ABc'], ['ABc', 'Abc', 'abc']),
]
Run Code Online (Sandbox Code Playgroud)
奖金测试案例
这是受Janne Karila在下面的评论的启发,目前选定的答案都失败了(但在我的案例中并不是真正的实际问题): …
簇是指一组相互连接的重叠圆。该图像可能会更好地说明我要查找的内容:

在我的数据中,圆由其中心坐标表示。我已经完成了碰撞检测,以生成代表重叠的成对中心点的列表:
pts = [(-2,2), (-2,2), (0,0), (2,1), (6,2), (7,1)]
overlaps = [
(pts[0], pts[1]),
(pts[0], pts[2]),
(pts[1], pts[2]),
(pts[2], pts[3]),
(pts[4], pts[5]),
]
Run Code Online (Sandbox Code Playgroud)
这是预期的结果:
expected_clusters = [
((-2,2), (-2,2), (0,0), (2,1)),
((6,2), (7,1))
]
Run Code Online (Sandbox Code Playgroud)
在实践中,我将使用的数据集约为这个大小,因此我可能永远都不需要扩大规模。但这并不是说我不会支持更理想的解决方案。
我提出了自己的幼稚解决方案,我将其发布为答案。但是我会对看到其他解决方案感兴趣。
这是我的测试:
@Test
public void randomDouble() {
int Min = -1;
int Max = 1;
double r;
for (int i = 0; i < 5; i++) {
r = Min + (Math.random() * ((Max - Min) + 1));
System.out.printf("%d %d: %.1f\n", Min, Max, r);
assertTrue(Max < r && Max > r);
}
}
Run Code Online (Sandbox Code Playgroud)
似乎在第一次运行循环中的assertTrue语句之后返回测试.如果我删除它,我得到5结果输出.有了它,我只得到一个.
我在Python中使用这种模式进行模糊测试.