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

Переделать программу без использования модуля

10.12.2010, 22:06. Показов 1122. Ответов 3
Метки нет (Все метки)

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


Задание (использование языка программирования 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
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.
модуль
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
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) и, разбивая
постранично, записать результат в исходный файл.


Добавлено через 39 минут
не получается так же скомпелировать модуль пишет что не знает тип переменых r и f

точней неизвестная переменная
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.12.2010, 22:06
Ответы с готовыми решениями:

Написать программу без использования массивов и строк!
Написать программу без использования массивов и строк! (x/1!)-(x3/3!)+(x5/5!)+(x7/7!)....

Составить программу для нахождения разности двух натуральных чисел без использования знака "-"
Добрый день, очень нужна помощь с двумя задачами для экзамена что то никак с ними разобраться не могу. 1) Составить программу для...

Переписать программу без использования if
Вывод должен быть тот же, только сама программа должна быть без if. var i,j,y,x,f:integer; a:array of integer; begin x:=1; ...

3
 Аватар для Monkey_2
36 / 36 / 9
Регистрация: 11.02.2009
Сообщений: 84
10.12.2010, 23:11
Цитата Сообщение от Isantel Посмотреть сообщение
interface
procedure sort_file(var f:text;r:Boolean);
implementation
procedure sort_file; {Сортировка текстового файла}
обявлина неправильно,поэтому и ненаходит f и r
1
13 / 13 / 1
Регистрация: 23.11.2010
Сообщений: 254
11.12.2010, 21:10  [ТС]
Цитата Сообщение от Monkey_2 Посмотреть сообщение
обявлина неправильно,поэтому и ненаходит f и r
как сделать правильно, скажите пожалуйста, программа не моя искал в интернете, а если можете то пожалуста скажите как сделать ее без модуля
0
 Аватар для Monkey_2
36 / 36 / 9
Регистрация: 11.02.2009
Сообщений: 84
11.12.2010, 23:51
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
uses
  DOS; { для pаботы функции FileExists }
  
 
var
  fi, fo: Text; { входной и выходной файл }
  s: String;
  c, p: Integer; { счетчик стpок и стpаниц }
 
{ возвpащает False - если файл S не существует и True - если существует }
{//////////////////////////////////////////////////////////////////////////////////////////}
procedure sort_file(var f:text;r:Boolean); {Сортировка текстового файла}
  {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};
 
{//////////////////////////////////////////////////////////////////////////////////////////}
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.
чета типа этого
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.12.2010, 23:51
Помогаю со студенческими работами здесь

Написать программу без использования функций
а как можно написать программу на паскале без function const n=20; var a,b:array of integer; i,j,k:integer; s:string; ...

Переделать программу без until/repeat
var n,m,i,j,k,l,r:longint; begin repeat write('n,m='); readln(n,m); until (m&gt;n)and (n&gt;0); for i:=n to m do...

Переделать программу без использования case upcase(st[i])
Здравствуйте, эту же программу можно сделать и без case upcase(st) of с помощью процедуры же можно сделать, только вот как, можно сделать...

Переделать программу без использования логической переменной
var a: array of integer; b: array of integer; i,j,n,m,n1,x: byte; sum,sr,o: integer; f: boolean; begin ...

Написать программу с использованием модуля CRT, без array
Написать программу, которая делит экран на 4 (равные) части закрашивает их в разные цвета.При этом надо чтобы окна появлялись с такой...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка 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 и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru