在看过Andrei Alexandrescu 的 D 的三个不太可能成功的优秀特征之后,我测试了那里给出的回文算法,如下所示
import std.exception;
bool isPalindrome(T)(T[] a)
{
for (; a.length > 1; a = a[1 .. $-1]) {
if (a[0] != a[$-1]) {
return false;
}
}
return true;
}
bool isPalindrome(Range)(Range r)
{
for (; !r.empty; r.popFront(), r.popBack()) {
if (a.front != a.back) {
return false;
}
}
return true;
}
unittest {
enforce(isPalindrome("dallassallad"));
}
数组版本在字符串上运行良好,但是当我将范围版本添加到同一个编译单元 DMD(2.062)时抱怨:
palindrome.d(31): Error: template palindrome.isPalindrome matches
more than one template declaration,
palindrome.d(10):isPalindrome(T)(T[] a) and
palindrome.d(20):isPalindrome(Range)(Range r)
我的猜测是限制使用范围不包括数组大小写。我怎么做?
我还测试了删除数组版本,但随后出现错误
/home/per/Work/cognia/palindrome.d(22): Error: no property 'empty' for type 'string'
/home/per/Work/cognia/palindrome.d(22): Error: undefined identifier 'popFront'
/home/per/Work/cognia/palindrome.d(22): Error: undefined identifier 'popBack'
/home/per/Work/cognia/palindrome.d(23): Error: undefined identifier a, did you mean variable r?
/home/per/Work/cognia/palindrome.d(23): Error: undefined identifier a, did you mean variable r?
/home/per/Work/cognia/palindrome.d(27): Warning: statement is not reachable
/home/per/Work/cognia/palindrome.d(31): Error: template instance palindrome.isPalindrome!(string) error instantiating
我似乎范围版本不适用于我觉得奇怪的数组。
该怎么办?