function IsValidExpression(ExprStr:String):Boolean;
const
Alpha_Number=['0'..'9','A'..'Z','a'..'z','_'];
Number=['0'..'9'];
CalChar=['+','-','*','/'];
type
TLastStatus=(lsCalChar,lsVariable,lsBracketbegin
,lsBracketEnd);
var
i,n,BracketCount,Len:Integer;
ch:Char;
Str:String;
LastStatus:TLastStatus;
begin
Result:=false;
Len:=Length(ExprStr);
i:=1;
BracketCount:=0;
LastStatus:=lsCalChar;
//初始化为运算符
while i<=Lendo
begin
ch:=ExprStr;
if ch in ['a'..'z','A'..'Z','_'] then
//变量
begin
if LastStatus in [lsVariable,lsBracketEnd] then
// "a1 b2" or ")d5"
exit;
if ch in ['a'..'g','A'..'G'] then
begin
Str:='';
Inc(i);
while i<=Lendo
begin
ch:=ExprStr;
if ch in Alpha_Number then
Str:=Str+ch
else
//变量名结束
break;
Inc(i);
end;
n:=StrToIntDef(Str,-1);
if (n<1) or (n>100) then
exit;
end
else
//变量名不是以 a..g 开头
exit;
LastStatus:=lsVariable;
end
else
if ch in Number then
//数字
begin
if LastStatus in [lsVariable,lsBracketEnd] then
// "a1 5" or "4 9"
exit;
Inc(i);
while i<=Length(ExprStr)do
begin
ch:=ExprStr;
if not (ch in Number) then
break;
Inc(i);
end;
if ch='.' then
//数字后紧跟着小数点...
begin
Inc(i);
while i<=Lendo
begin
ch:=ExprStr;
if not (ch in ['0'..'9']) then
break;
Inc(i);
end;
if ch='.' then
//数字中有两个小数点
exit;
end;
LastStatus:=lsVariable;
end;
if i>Len then
break;
case ch of
'(': //括号计算
begin
if LastStatus in [lsVariable,lsBracketEnd] then
// "12(" or ")("
exit;
Inc(BracketCount);
LastStatus:=lsBracketbegin
;
end;
')': //括号计算
begin
Dec(BracketCount);
if BracketCount<0 then
//出现了右括号比左括号多的情况...
exit;
if LastStatus in [lsBracketbegin
,lsCalChar] then
// () or +)
exit;
LastStatus:=lsBracketend;
end;
else
begin
if ch in CalChar then
begin
if LastStatus in [lsBracketbegin
,lsCalChar] then
// (+ or *-
exit;
LastStatus:=lsCalChar;
end
else
if ch>' ' then
//其它可见字符——表达式中有非法字符
exit;
end;
end;
Inc(i);
end;
//括号数量正确 and 以变量或右括号结束
Result:=(BracketCount=0) and (LastStatus in [lsVariable,lsBracketEnd]);
end;