• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Турбо Паскаль. Файлы, работа с текстом

Светик123

Новые
Регистрация
2 Мар 2014
Сообщения
32
Реакции
0
Баллы
0
Турбо Паскаль. Файлы, работа с текстом

нужна помощь. требуется переделать программу, представленную ниже, под работу с файлами. то есть считывание из файла координат х, у и запись в файл полярного угла и радиуса
код программы:
Uses crt;
Type
Cartez=Record
x,y:real;
end;
Polar=Record
R,fi:real;
end;
Procedure Cart2Pol(Cr:Cartez; var Pl:Polar);
begin
Pl.R:=sqrt(sqr(Cr.x)+sqr(Cr.y));
with Cr do
if (x>0) and (y>=0) then Pl.fi:=Arctan(y/x) else
if (x=0) and (y>0) then Pl.fi:=Pi/2 else
if (x<0) and (y>=0) then Pl.fi:=Pi+Arctan(y/x) else
if (x<0) and (y<0) then Pl.fi:=-Pi+Arctan(y/x) else
if (x=0) and (y<0) then Pl.fi:=-Pi/2 else
if (x>0) and (y<0) then Pl.fi:=Arctan(y/x) else
Pl.fi:=10;
end;

{VVOD PEREMENNOY}
procedure vvod(var a:real); {A - PARAMETR-PEREMENNAYA DLYA HRANENIYA VVEDENNOGO ZNACHENIYA}
var ST:string; {ST - STROKA DLYA NEPOSREDSTVENNOGO VVODA}
E:integer; {E - PEREMENNAYA DLYA HRANENIYA KODOV OSHIBOK}
begin
repeat
readln(ST);
val(ST,A,E);
if E<>0 then begin
writeln('Necorrectnoe znachenie ''',ST,'''. Povtorite vvod:')
end
until E=0;
end;
Var
C:Cartez;
P:Polar;
Begin
clrscr;
writeln ('Programma perevodit koordinati tochki is dekartovoi sistemi v poliarnuy');
with C do begin
writeln('Vvedite x:');
vvod(x);
writeln('Vvedite y:');
vvod(y)
end;
Cart2Pol(C,P);
Writeln ('Polyarnie koordinati:');
Writeln('Radius = ',P.R:0:2);
if P.fi=10 then
Writeln('Poliarnii ugol - Ne opredelen')
else
Writeln('Poliarnii ugol = ',P.fi{/Pi*180}:0:2);
Readln
End.
Заранее спасибо
 
требуется переделать программу, представленную ниже, под работу с файлами.
Это-то можно, только объясните сначала, зачем Вы сделали ввод чисел через преобразование строковой переменной? Это как у классиков: "достать правое ухо через-под левое колено".
 
это сделано для того, чтобы пользователь но смог символ ввести. требования такие, тут от меня ничего, к сожалению, не зависит(
 
это сделано для того, чтобы пользователь но смог символ ввести. требования такие, тут от меня ничего, к сожалению, не зависит(
Понятно. Ну что же, можно и так.
Вот с файлами. Естественно, имена файлов, а также пути к ним можете поправить сообразно своему вкусу.
Код:
Type
 Cartez=Record
         x,y:real;
        end;
  Polar=Record
         R,fi:real;
        end;

Procedure Cart2Pol(Cr:Cartez; var Pl:Polar);
begin
 Pl.R:=sqrt(sqr(Cr.x)+sqr(Cr.y));
 with Cr do
  if (x>0) and (y>=0) then Pl.fi:=Arctan(y/x) else
  if (x=0) and (y>0) then Pl.fi:=Pi/2 else
  if (x<0) and (y>=0) then Pl.fi:=Pi+Arctan(y/x) else
  if (x<0) and (y<0) then Pl.fi:=-Pi+Arctan(y/x) else
  if (x=0) and (y<0) then Pl.fi:=-Pi/2 else
  if (x>0) and (y<0) then Pl.fi:=Arctan(y/x) else
  Pl.fi:=10;
end;

Var
 C:Cartez;
 P:Polar;
 f1,f2:Text;
 IOR:Integer;

Begin
 {$I-}
 Assign(f1,'D:\Cart.txt');
 Reset(f1);
 Assign(f2,'D:\Polar.txt');
 Rewrite(f2);
 Read(f1,C.x,C.y);
 IOR:=IOResult;
 If IOR=0 then
  begin
   Cart2Pol(C,P);
   Writeln(f2,'Radius = ',P.R:0:2);
   if P.fi=10 then Writeln(f2,'Poliarnii ugol - Ne opredelen')
   else Writeln(f2,'Poliarnii ugol = ',P.fi:0:2);
  end
 else
  begin
   writeln('Oshibka chtenija vhodnyh dannyh');
   Readln
  end;
 Close(f1);
 Close(f2);
End.
 
Назад
Сверху