Спрограммой (pascal), не знаю, где ошибка и как ее исправить : найти произведение длин самой длинной и k-й строк. var f: text; s: string; max,n: integer; begin assign(f,'1.txt'); reset(f); readln(f,s); n: =length(s); max: =n; while not eof(f) do begin readln(f,s); if length(s)> max then max: =length(s); end; close(f); writeln('длина самой длинной строки: ',max); writeln('длина k строки: ',n); writeln('произведение длин самой длинной и k строк: ', max*n); end.
Итого код:
var f:text;
s:string;
max,n,k:longword;//longword - беззнаковый аналог integer (если не будет работать, надо заменить обратно на intger)
begin
read(k);//Или откуда там мы берем это число k?..
assign(f,'1.txt');
reset(f);
readln(f,s);
n:=length(s);
max:=n;
while (not eof(f)) and (k>0) do
begin
k-=0;
readln(f,s);
if length(s)> max then max:=length(s);
end;
n:=length(s);
while not eof(f) do begin
readln(f,s);
if length(s)> max then max:=length(s);
end;
close(f);
writeln('Длина самой длинной строки: ',max);
writeln('Длина k строки: ',n);
writeln('Произведение длин самой длинной и k-ой строки: ', max*n);
end.
Обращайтесь (/обращайся), если что-то не понятно, я попробую объяснить, причем как в этом решении, так и вообще в самом принципе решения.