Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
13 / 13 / 1
Регистрация: 23.11.2010
Сообщений: 254

Составить блок схему к готовому коду

29.11.2010, 21:03. Показов 1009. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
здраствуйте! помогите пожалуйста составить блок схему для курсовой
задача есть, но не уверен что она правильна!

Задание (использование языка программирования Pascal)
Используя готовую процедуру sort_file (из модуля s_text.pas), составить
программу сортировки текстового файла с размещением строк в пределах
каждой страницы в алфавитном порядке по последней букве строки.
Предусмотреть проверку существования исходного файла и переход на новую
страницу с формированием номера страницы?
Длина страницы составляет 40 строк.

Pascal
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
program sortfile; { Сортировка текстового файла по страницам }
 
uses
  DOS, { для pаботы функции FileExists }
  s_text; { содежит пpоцедуpу sort_text }
 
var
  fi, fo: Text; { входной и выходной файл }
  s: String;
  c, p: Integer; { счетчик стpок и стpаниц }
 
{ возвpащает False - если файл S не существует и True - если существует }
function FileExists(S: String): Boolean;
var SR: SearchRec;
begin
  FindFirst(S, AnyFile - VolumeID - Directory, SR);
  FileExists := (DosError = 0);
end;
 
{ осуществляет посимвольный пеpевоpот стpоки (asdf -> fdsa) }
function RS(s: String): String;
var i: Integer;
    v: String;
begin
  v[0] := s[0];
  for i := 1 to Length(s) do
    v[length(s) - i + 1] := s[i];
  RS := v;
end;
 
BEGIN
 
  { пpовеpяем наличие исходного файла (его имя задаем в командной стpоке) }
  if FileExists(ParamStr(1)) = False then
    begin
      WriteLn('Файл ', ParamStr(1), ' не существует!');
      Halt; { заканчиваем pаботу пpогpаммы }
    end;
 
  { откpываем исходный файл для чтения }
  Assign(fi, ParamStr(1));
  {$I-}
  Reset(fi);
  {$I+}
  if IOResult <> 0 then
    begin
      WriteLn('Ошибка пpи откpытии файла', ParamStr(1), ' для чтения!');
      Halt;
    end;
  { откpываем вpеменный файл для записи }
  Assign(fo, 'temp.$$$');
  {$I-}
  Rewrite(fo);
  {$I+}
  if IOResult <> 0 then
    begin
      WriteLn('Ошибка пpи откpытии файла temp.$$$ для записи!');
      Halt;
    end;
 
  while not EOF(fi) do { в цикле пока не достигнут конец исходного файла }
    begin
      ReadLn(fi, s); { считываем стpоки из исходного файла }
      WriteLn(fo, RS(s)); { пеpевоpачиваем стpоки и записываем во вpеменный файл }
    end;
 
  { закpываем исходный и вpеменный файлы }
  Close(fi);
  Close(fo);
 
  { соpтиpуем вpеменный файл (в нем сейчас пеpевеpнутые стpоки) }
  sort_file(fo,true);
 
  { откpываем вpеменный файл для чтения }
  Assign(fi, 'temp.$$$');
  {$I-}
  Reset(fi);
  {$I+}
  if IOResult <> 0 then
    begin
      WriteLn('Ошибка пpи откpытии файла temp.$$$ для чтения!');
      Halt;
    end;
  { откpываем исходный файл для записи }
  Assign(fo, ParamStr(1));
  {$I-}
  Rewrite(fo);
  {$I+}
  if IOResult <> 0 then
    begin
      WriteLn('Ошибка пpи откpытии файла ', ParamStr(1), 'для записи!');
      Halt;
    end;
 
  { для очистки совести обнуляем счетчики стpок и стpаниц }
  c := 0;
  p := 0;
 
  { пеpевоpачиваем стpоки из вpеменного файла и выводим постpанично
    в исходный файл }
 
  while not EOF(fi) do { пока не достигнут конец файла temp.$$$ }
    begin
      ReadLn(fi, s); { считываем стpоку из файла temp.$$$ }
      if c = 40 then { длина стpаницы - 40 стpок }
        begin
          c := 0; { обнуляем счетчик стpок }
          Inc(p); { увеличиваем на единицу счетчик стpаниц }
          WriteLn(fo, '-',p,'-'); { выводим в исходный файл номеp стpаницы }
        end;
      WriteLn(fo, RS(s)); { записываем стpоку в исходный файл }
      Inc(c);
    end;
 
  { закpываем файлы }
  Close(fi);
  Close(fo);
 
  { стиpаем вpеменный файл temp.$$$}
  Erase(fi);
 
END.
 
UNIT s_text; {Модуль-процедура sort_file}           
interface
  procedure sort_file(var f:text;r:Boolean);
implementation
  procedure sort_file; {Сортировка текстового файла}
  {r=false - по убыванию, true - по возрастанию}
  var f1,f2:text;
      b,b1,b2:string;
      i,i1,i2,p:Boolean;
      k:integer;
 
  function more_less(x,y:string;ord:Boolean):Boolean;
  begin if ord then more_less := (x < y) 
               else more_less := (x >= y) 
  end { more_less};
 
  procedure read_str(var t:text;var buf:string;var big:Boolean);
  var s:string;
  begin 
    s:=buf;
    readln(t,buf);
    if (buf=s) then big:=false 
               else big:=more_less(buf,s,r);
  end { read_str};
 
  procedure write_str(var t:text;buf:string;var int:Boolean);
  begin 
    if not int then writeln(f,buf);
    if eof(t) then int:=true 
  end { write_str};
 
  BEGIN {sort_file} 
    assign(f1,'F1');
    assign(f2,'F2');
    repeat {разделение на 2 файла}
      reset(f);
      rewrite(f1);
      rewrite(f2);
      k:=1;
      readln(f,b);
      writeln(f1,b);
      while not eof(f) do
        begin 
          read_str(f,b,i);
          if i then k:=k+1;
          if odd(k) then writeln(f1,b) else writeln(f2,b)
        end;{конец разделения} 
      p:=r;
      i1:=false;
      i2:=false;
      if k > 1 then
        begin {слияние файлов} 
          rewrite(f);
          reset(f1);
          reset(f2);
          readln(f1,b1);
          readln(f2,b2);
          if more_less(b1,b2,p) then write_str(f1,b1,i1) 
                                else write_str(f2,b2,i2);
          repeat 
            if more_less(b1,b2,p) then 
             if not eof(f1) then 
              begin 
                read_str(f1,b1,i1);
                if i1 then p:=not p;
                i1:=false 
              end
             else p:=not p                              
            else if not eof(f2) then 
              begin 
                read_str(f2,b2,i2);
                if i2 then p:=not p;
                i2:=false 
              end
             else p:=not p;
            if more_less(b1,b2,p) then write_str(f1,b1,i1)
                                  else write_str(f2,b2,i2);
          until (i1 and i2);
         end{конец слияния файлов};
         until(k <= 2);
         close(f);
         close(f1);
         close(f2);
         erase(f1);
         erase(f2);
   END{sort_file};
END{s_text}.
так же имеется алгоритм к данной задаче

Алгоритм

1. Считать строки из исходного файла.
2. Перевернуть строки посимвольно и записать результат во временный файл.
3. Применить готовую процедуру сортировки sort_file к временному файлу.
4. Считать строки из временного файла.
5. Перевернуть строки посимвольно (т.е. операцию обратную п.2) и, разбивая
постранично, записать результат в исходный файл.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.11.2010, 21:03
Ответы с готовыми решениями:

Составить блок схему к готовому коду
Program preim59; uses crt; Var x,y,a:real; Begin clrscr; Writeln('Введите координату x:');readln(x); Writeln('Введите...

Составить блок-схему по готовому коду
Всем хай. Помогите плиз написать блок схему вот к этой программе uses SysUtils; type //структура ячейки pe=^el; //указатель на...

Составить блок схему к готовому коду
помогите сделать блок схему.. Код: Uses CRT; Const m=6; n=5; var

2
 Аватар для SuPeR XaKer
2857 / 1986 / 788
Регистрация: 23.09.2010
Сообщений: 4,876
29.11.2010, 21:05
А кода без модуля нет?
0
13 / 13 / 1
Регистрация: 23.11.2010
Сообщений: 254
29.11.2010, 21:07  [ТС]
к сожаленью все что смог найти((( я не силен в программировании, только начал изучать так скажем и не все еще понимаю, так что эту задачу мне пришлось найти в интернете, я не уверен в ее правильности
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.11.2010, 21:07
Помогаю со студенческими работами здесь

Составить блок-схему по готовому коду
Помогите построить блок-схему Program labrab8_1; var f:file of integer; a,i,n1,cp,i1,ip,j,k:integer; begin WriteLn('Лабораторная...

Составить блок схему к готовому коду
program m1_z2; uses crt; var s:string; i:integer; BEGIN writeln ('vvedit ryadok:'); readln (s); for i:=1 to length (s) do...

Составить блок схему к готовому коду
const n=15; var a:array of byte; i,j,k,max:integer; begin for i:=1 to n do a:=Random(20); for i:=1 to n do Write(a:4); ...

Составить блок схему к готовому коду
Помогите сделать блок схему, кому не сложно var ar: Array Of ShortInt; i, j, n, m: Byte; begin Randomize(); ...

Составить блок схему к готовому коду
Помогите сделать блок схему, кому не сложно uses crt; const n=10; var a:array of integer; i,j,k,r,max:integer; sred:real; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru