![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() |
Aleks |
![]()
Сообщение
#1
|
Новичок ![]() Группа: Пользователи Сообщений: 23 Пол: Мужской Репутация: ![]() ![]() ![]() |
Здраствуйте
Прошу помощи в решение задачи: Подсчитать число вершин на n-ом уровне непустого дерева Т (корень считать вершиной нулевого дерева) я в этом плохо разбираюсь, но кое-что написал Исходный код uses crt; type pitem=^titem; titem=record data:string; pred:pitem; next:pitem; end; var first,last:pitem; ff:text; ss:string; i:integer; procedure add(ss:string); var newitem:pitem; d:string; begin for i:=1 to length(ss) do begin d:=ss[1+length(ss)-i]; new(newitem); newitem^.data:=d; newitem^.pred:=nil; newitem^.next:=first; first:=newitem; if last=nil then last:=newitem; end; end; procedure print; begin end; procedure del; var delitem:pitem; begin delitem:=first; if delitem<>nil then begin first:=delitem^.next; delitem^.Pred^.Next:=delitem^.Next; dispose(delitem); end; end; begin { clrscr; } writeln('--' , memavail); assign(ff,'E:\derevo.txt'); reset(ff); while not (eof(ff)) do begin readln(ff,ss); writeln(ss); end; add(ss); del; close(ff); writeln('--' , memavail); readln; end. |
![]() ![]() |
Aleks |
![]()
Сообщение
#2
|
Новичок ![]() Группа: Пользователи Сообщений: 23 Пол: Мужской Репутация: ![]() ![]() ![]() |
есть файл derevo.txt , с которого считываются данные (дерево методом вложенных скобок (0(1(2((5)(6)))(3)(4))(7((8)(9(1))))) )
я решил сделать так Код for i:=1 to length(ss) do begin {write('- ',d);} case ss[i] of '0'..'9': begin add(T,ss[i]); write(' ',ss[i],' '); end; '(': zn:=true; ')': zn:=false; end; end; но как сделать в процедуре add я предположил так, но здесь не совсем правильно, дерево должно ветвится 0-1-2-5 -------6 -----3 -----4 ---7-8 -----9-1 Код begin if t<>nil then with t^ do begin if zn=true then Add(Right,i) else if zn=false then Add(Left,i) else Inc(Data.Count) end else CreateNode(T,i); end; помогите, в каком направление думать Сообщение отредактировано: Aleks - 6.09.2005 14:28 |
![]() ![]() |
![]() |
Текстовая версия | 21.07.2025 16:44 |