csharp高级练习题:观察到的PIN【难度:4级】:
好吧,侦探,我们的一位同事成功地观察我们的目标人物,罗比强盗.我们跟随他到一个秘密仓库,在这里我们假设找到所有被盗的东西.门此仓库是由一个电子组合锁固定.不幸的是我们的间谍是不知道他看到,当罗比进入它的PIN.
键盘具有以下布局:
┌───┬───┬───┐
│1│2│3│
├───┼───┼───┤
│4│5│6│
├───┼───┼───┤
│7│8│9│
└───┼───┼───┘
││0
└───┘
他指出,PIN1357
,但他也说,这是可能的,每个他看到实际上可能是另一个相邻位数字(水平或垂直,而不是对角).例如.而不是1
它也有可能是2
或4
.取而代之的5
它也有可能是2
,4
,6
或8
.
他还提到,他知道这种锁.您可以输入错针脚无限量的,他们从来没有最后锁定系统或发出警报.这就是为什么我们可以尝试所有可能的(*)的变化.
\ * 在感可能的:观察到的PIN本身和所有的变化考虑在相邻的位
你能帮助我们找到那些变化?这将是很好有一个功能,即返回所有变型的数组矩阵(或在Java和C# 的列表),用于以1至8位的长度的观察到的PIN.我们可以命名函数getPINs
(在pythonget_pins
,GetPINs
在C#).但请注意,所有的PIN,所观察到的一个,也是成绩,必须是字符串,因为有可能导致"0’.我们已经准备了一些测试用例你.
侦探,我们指望你了!
对于C# 用户:不要使用单声道. Mono是当运行你的代码也慢.
编程目标:
using System.Collections.Generic;
public class Kata
{
public static List GetPINs(string observed)
{
return null;