Text39. Дано целое число $$K$$ $$(> 25)$$ и текстовый файл, содержащий текст, выровненный по левому краю. Абзацы выделяются в нем с помощью красной строки ($$5$$ начальных пробелов), а пустых строк нет. Отформатировать текст так, чтобы его ширина не превосходила $$K$$ позиций, и выровнять текст по левому краю, сохранив деление на абзацы. Пробелы в конце строк удалить. Сохранить отформатированный текст в новом текстовом файле.
Решение:
Перенос по символам, если перенос попадает на середину слова то слово переносится частично.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 |
program Text39; var F_in,F_out: Text; Name,S2,S1,TempString,line:string; K:integer; Procedure DelRightSpace(var S:String); begin if Length(S)>0 then While (S[Length(S)]=' ') and (length(s)>0) do Delete(S,Length(S),1); end; Procedure CutString(len:integer;var S,SCut:String); begin SCut:=Copy(S,1,len); Delete(S,1,len); end; begin Write('File name in: '); Readln(Name); Assign(F_in,Name); Write('File name out: '); Readln(Name); Assign(F_out,Name); Write('K: '); Readln(K); Reset(F_in); Rewrite(F_out); S1:=''; S2:=''; TempString:=''; While not eof(F_in) do begin S2:=S1; Readln(F_in,S1); DelRightSpace(S1); TempString:=TempString+S2; While (length(TempString)>=K) do begin CutString(K,TempString,line); Writeln(F_out,line); end; if (pos(' ',S1)=1) and (TempString<>'') then begin Writeln(F_out,TempString); TempString:=''; end; end; Close(F_in); While (length(TempString)>=K) do begin CutString(K,TempString,line); Writeln(F_out,line); end; Close(F_out); end. |
Перенос по словам:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 |
program Text39; var F_in,F_out: Text; Name,S2,S1,TempString,line:string; K:integer; Procedure DelRightSpace(var S:String); begin if Length(S)>0 then While (S[Length(S)]=' ') and (length(s)>0) do Delete(S,Length(S),1); end; Procedure CutString(len:integer;var S,SCut:String); begin SCut:=''; if pos(' ',S)=1 then begin SCut:=' '; Delete(S,1,5); len:=len-5; end; if (pos(' ',S)>len) then begin SCut:=SCut+Copy(S,1,len); Delete(S,1,len); end else begin while (length(SCut+Copy(S,1,pos(' ',S)-1))<=len) do begin if SCut<>'' then SCut:=SCut+' '; SCut:=SCut+Copy(S,1,pos(' ',S)-1); Delete(S,1,pos(' ',S)); end; end; end; begin Write('File name in: '); Readln(Name); Assign(F_in,Name); Write('File name out: '); Readln(Name); Assign(F_out,Name); Write('K: '); Readln(K); Reset(F_in); Rewrite(F_out); S1:=''; S2:=''; TempString:=''; While not eof(F_in) do begin S2:=S1; Readln(F_in,S1); DelRightSpace(S1); Writeln(S1); TempString:=TempString+S2; While (length(TempString)>=K) do begin CutString(K,TempString,line); Writeln(F_out,line); end; if (pos(' ',S1)=1) and (TempString<>'') then begin Writeln(F_out,TempString); TempString:=''; end; end; Close(F_in); While (length(TempString)>=K) do begin CutString(K,TempString,line); Writeln(F_out,line); end; Close(F_out); end. |
Другие задачи из раздела Text можно посмотреть здесь.
Комментарии: