function Trail(n: Integer): Integer;
var
Mask: Integer;
begin
T := 0;
while (T < SizeOf(Integer)*8) do
begin
Mask := 1 shl T;
if (n and Mask) <> 0 then Exit;
Inc(T);
end;
end;
begin
writeln(Trail(112),' (should be 4)');
end.
SizeOf(Integer) depends on the compiler mode and bitness of the OS you are compiling for.
Converts the integer in scalar variable $n into a string of zeros and ones. Extract characters from the end of the string until a non-zero is found. (A character 0 is treated as false, a 1 as true.) Stop when we reach the start of the string.
sprintf %b converts $n from an integer to a string of 1's and 0's. This is then matched (using the =~ operator) against a regular expression which looks for one or more zeroes at the end of the string. The parens around 0+ form a capture group which is accessible via the variable $1 and will contain the string of trailing 0's. If the match succeeds, then the length of $1 is computed and returned; if not, then a length of zero is returned.
function Trail(n: Integer): Integer;
var
Mask: Integer;
begin
T := 0;
while (T < SizeOf(Integer)*8) do
begin
Mask := 1 shl T;
if (n and Mask) <> 0 then Exit;
Inc(T);
end;
end;
begin
writeln(Trail(112),' (should be 4)');
end.