得到"布尔"预期" LongInt"帕斯卡

时间:2015-01-24 11:46:37

标签: boolean pascal long-integer bubble-sort insertion-sort

我的插入排序算法出现了这个错误:

  

insertionsort.lpr(19,17)错误:不兼容的类型:得到“布尔”预期“LongInt”

这是我的代码第19行

 while j > 0 and A[j]>key do            

我在互联网上试过谷歌搜索,但我找不到任何语法错误或任何东西。

如果有帮助,这是完整的代码:

program instert;
uses crt;
const
  N = 5;
var
   i:integer;
   j:integer;
   key:integer;
   A : Array[1..N] of Integer;


procedure insertionsort;
  begin
  for i := 2 to N  do
    begin
    key := A[1];
    j:= i - 1;
        while j > 0 and A[j]>key do
        begin
          A[j+1] := A[j] ;
          j := j-1;
        end;
    A[j+1] := key ;
   end;
 end;

begin
  A[1]:= 9;
  A[2]:= 6;
  A[3]:= 7;
  A[4]:= 1;
  A[5]:= 2;
  insertionsort;
end.

我在冒泡排序算法上也遇到了同样的错误。这是错误行

  

bubblesort.lpr(26,14)错误:不兼容的类型:得到“布尔”预期“LongInt”

这是我算法的第26行:

 until flag = false or N = 1 ;   

这是完整的代码:

program bubblesort;
uses crt;

var
  flag:boolean;
  count:integer;
  temp:integer;
  N:integer;
  A : Array[1..N] of Integer;

procedure bubblesort ;
begin
  Repeat
    flag:=false;
    for count:=1 to (N-1)  do
    begin
    if A[count] > A[count + 1] then
       begin
       temp := A[count];
       A[count] := A[count + 1];
       A[count] := temp;
       flag := true;
       end;
    end;
    N := N - 1;
  until flag = false or N = 1 ;
end;

begin
  A[1]:= 9;
  A[2]:= 6;
  A[3]:= 7;
  A[4]:= 1;
  A[5]:= 2;
  N := 5;
  bubblesort;
end.

1 个答案:

答案 0 :(得分:7)

在Pascal中,布尔运算符andor的优先级高于比较运算符>=等。所以在表达式中:

while j > 0 and A[j] > key do

鉴于and具有更高的优先级,Pascal将其视为:

while (j > (0 and A[j])) > key do

0 and A[j]被评估为按位and(因为参数是整数),从而产生整数。然后比较,j > (0 and A[j])被评估为布尔结果,并使用> key检查boolean > longintlongint。然后,您会收到错误,即boolean而不是while (j > 0) and (A[j] > key) do ... 进行算术比较。

修复它的方法是括号:

until flag = false or N = 1 ;

同样的问题适用于此声明:

or

会产生错误,因为=的优先级高于until (flag = false) or (N = 1); 。所以你可以括起来:

until not flag or (N = 1);    // NOTE: 'not' is higher precedence than 'or'

或者,对于布尔人来说更具规范性:

{{1}}

如果对运算符的优先级有疑问,括号内是一个好主意,因为它消除了对将要发生的订单操作的疑问。