вот условие: Используя очередь и стек из входного текстового файла F проанализировать текст сбалансированный по скобкам <Текст>::=<пусто> | <элемент><текст> <элемент>::=<буква> | (<текст>) Напечатать упорядоченные пары номеров открывающих скобок.
type TForm1 = class(TForm) Memo1: TMemo; Button1: TButton; OpenDialog1: TOpenDialog; Label1: TLabel; procedure Button1Click(Sender: TObject); private { Private declarations } public { Public declarations } end;
var Form1: TForm1;
implementation
{$R *.DFM}
procedure TForm1.Button1Click(Sender: TObject); var i,y:integer; stek:Integer; //Для стека достаточно одного символа str:string; begin
IF openDialog1.Execute then Memo1.Lines.LoadFromFile(OpenDialog1.FileName);
stek:=-1;
For i:= 0 to MEmo1.Lines.Count-1 do For y:= 1 to Length(Memo1.Lines[i]) do Begin str:=Memo1.Lines[i];
If ( str[y]='(' ) then if ( stek<0 ) then Begin Stek:=y; end else Begin Label1.Caption:=Label1.Caption+IntToStr(stek)+'-'+IntToStr(y)+' '; Stek:=-1; end;
End;
end;
end.
Результатом будет : 10-15
.*Pas
22.04.2005 21:41
в общем я уже голову себе сломал с этими Дельфями,помогите пожалуйста...пост выше мой
Guest
22.04.2005 21:46
вот ещё есть на Паскале решение,но мне надо на Турбовом решить
Код
procedure TForm1.Button1Click(Sender: TObject); var i,y:integer; stek:Integer; //Для стека достаточно одного символа str:string; begin IF openDialog1.Execute then Memo1.Lines.LoadFromFile(OpenDialog1.FileName); stek:=-1; For i:= 0 to MEmo1.Lines.Count-1 do For y:= 1 to Length(Memo1.Lines[i]) do Begin str:=Memo1.Lines[i]; If ( str[y]='(' ) then if ( stek<0 ) then Begin Stek:=y; end else Begin Label1.Caption:=Label1.Caption+IntToStr(stek)+'-'+IntToStr(y)+' '; Stek:=-1; end; End; end; end.
volvo
22.04.2005 22:08
Ну, так в чем дело? Есть ведь алгоритм, ну и реализуй его на Турбо-Паскале:
function intToStr(x: integer): string; var s: string; begin str(x, s); intToStr := s; end;
var y:integer; stek:Integer; caption, str:string; f: text; begin assign(f, '_t_.txt'); reset(f);
stek := -1; while not eof(f) do begin readln(f, str); for y := 1 to length(str) do begin if str[y] = '(' then if stek < 0 then begin stek := y; end else begin Caption := Caption + IntToStr(stek)+'-'+IntToStr(y)+' '; writeln(caption); Stek := -1; end; end; end; close(f); end.
Вместо того, чтобы работать напрямую со строкой, можешь загнать ее в очередь, и работать с очередью символов, если это тебе нужно... Алгоритмы и исходники работы с очередями - в FAQ (или поиск)... В общем, смотри мою подпись
*.pas
23.04.2005 18:40
спасибо за совет,но кто-нибудь может мне здесь помочь с реализацией на Турбо Паскаль этого алгоритма?
В Поиске посмотри... Ты думаешь, только тебе это нужно сделать? Или тебе самому думать "в лом", хочется получить все готовое? Тогда ты ошибся...
*.pas
24.04.2005 7:34
да ладно постараюсь сам
Продолжай изобретать колесо (даже НЕ велосипед, именно колесо !!!) и лезть в окно, когда дверь - то открыта. Я же тебе и адреса дал, что, ВСЁ надо сделать и выложить на блюдечке? Этого не будет...
Закрыто
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.