IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> запись из одного файла в другой, (работа с типизированными файлами)
сообщение
Сообщение #1


Профи
****

Группа: Пользователи
Сообщений: 920
Пол: Женский
Реальное имя: Марина

Репутация: -  2  +


Вот такая задача:
написать программу, которая читает из типизированного файл целые числа, умножает их на 2 и записывает их в другой типизированный файл.

после ввода чисел постоянно получаю ошибку disk read error, а ввыходной файл ничего не записывается...


program zach_9_4;
uses crt;
const
n = 10;
procedure save_file ( Filename : string );
var
f : file of real;
a : real;
i : byte;
begin
assign (f, filename);
rewrite (f);
for i := 1 to n do
begin
read (a);
write (f, a);
end;
close (f);
end;
procedure print_file( filename : string );
var
f : file of real;
i : byte;
a : real;
begin
assign (f, filename);
reset (f);
i := 1;
while i <= n do
begin
read (f, a);
writeln (a:4:2);
i := i + 1;
end;
close (f);
end;
procedure basis_part( fnin, fnout : string );
var
fin, fout : file of real;
a : real;
i : byte;
p : real;
begin
assign (fin, fnin);
assign (fout, fnout);
reset (fin);
rewrite (fout);
p := 1;
i :=1;
while i <= n do
begin
if frac(a) = 0 then
begin
read (fin, a);
p := p*a*2;
write (fout, p);

end;
i:=i+1;
end;
close (fin);
close (fout);
end;

BEGIN
clrscr;
save_file ( 'file1.bin' );
print_file ( 'file1.bin' );
basis_part ('file1.bin', 'file1_out.bin');
print_file ('file1_out.bin');
readkey;
end.



Сообщение отредактировано: 18192123 -
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #2


просто человек
******

Группа: Пользователи
Сообщений: 3 641
Пол: Женский
Реальное имя: Юлия

Репутация: -  55  +


  if frac(a) = 0 then 

и чему равно а на первом проходе?
вот это - тоже что-то не то
  p := p*a*2;

у тебя будет идти накопление произведения.

и еще.
почему ты не хочешь вместо
while i <= n do
сделать
while not(EOF(f)) do
?


--------------------
Все содержимое данного сообщения (кроме цитат) является моим личным скромным мнением и на статус истины в высшей инстанции не претендует.
На вопросы по программированию, физике, математике и т.д. в аське и личке не отвечаю. Даже "один-единственный раз" в виде исключения!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Профи
****

Группа: Пользователи
Сообщений: 920
Пол: Женский
Реальное имя: Марина

Репутация: -  2  +



вот что теперь получается, исходный файл выводит нормально, а дальше ничего...
и еще я не знаю, как поступить с
if frac(a) = 0 then



uses crt;
const
n = 3;
procedure save_file ( Filename : string );
var
f : file of real;
a : real;
i : byte;
begin
assign (f, filename);
rewrite (f);
for i := 1 to n do
begin
read (a);
write (f, a);
end;
close (f);
end;
procedure print_file( filename : string );
var
f : file of real;
i : byte;
a : real;
begin
assign (f, filename);
reset (f);
while not eof(f) do
begin
read (f, a);
writeln (a:4:2);

end;
close (f);
end;
procedure basis_part( fnin, fnout : string );
var
fin, fout : file of real;
a : real;
i : byte;

begin
assign (fin, fnin);
assign (fout, fnout);
reset (fin);
rewrite (fout);
while not eof(fin) do
begin
if frac(a) = 0 then
begin
a := a*2;
write (fout, a);

end;
end;
close (fin);
close (fout);
end;

BEGIN
clrscr;
save_file ( 'file1.bin' );
print_file ( 'file1.bin' );
basis_part ('file1.bin', 'file1_out.bin');
writeln ( '=========================');
print_file ('file1_out.bin');
readkey;
end.

 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #4


Гость






procedure basis_part( fnin, fnout : string );
var
fin, fout : file of real;
a : real;
i : byte;
begin
assign (fin, fnin); reset (fin);
assign (fout, fnout); rewrite (fout);
while not eof(fin) do
begin
read(fin, a); { <--- Ты же не читала из файла... }
if frac(a) = 0 then
begin
a := a*2;
write (fout, a);

end;
end;
close (fin); close (fout);
end;
 К началу страницы 
+ Ответить 
сообщение
Сообщение #5


Профи
****

Группа: Пользователи
Сообщений: 920
Пол: Женский
Реальное имя: Марина

Репутация: -  2  +


Цитата(Алена @ 10.12.2006 17:12) *

procedure basis_part( fnin, fnout : string );
var
fin, fout : file of real;
a : real;
i : byte;
begin
assign (fin, fnin); reset (fin);
assign (fout, fnout); rewrite (fout);
while not eof(fin) do
begin
read(fin, a); { <--- Ты же не читала из файла... }
if frac(a) = 0 then
begin
a := a*2;
write (fout, a);

end;
end;
close (fin); close (fout);
end;


ой! и правда! кажется я снова страдаю от своей невнимательности...
спасибо!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 27.09.2020 5:32
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name