Помощь - Поиск - Пользователи - Календарь
Полная версия: задача на паскале.матрица (другая)
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
Roman1
помогите пожалуйста:
Считать из текстового файла Beg.txt матрицу Р(2,10). Элементы столбцов соответственно абсцисса и ордината одной из десяти точек плоскости. Если нет ни одной пары точек, расстояние между которыми меньше заданной величины R, заменить на нуль в матрице Р все отрицательные абсциссы точек, увеличив ординаты этих точек на R. Результат записать в файл Rez.txt.
Если получится, то сегодня
Bokul
uses crt;
const r=-10;
type
main=array[1..10,1..2]of integer;


procedure read_array(s:string; var mas:main);
var f: file of main;
begin
assign(f,s);
reset(f);
read(f,mas);
close(f);
end;

procedure write_array(s:string; mas:main);
var f:file of main;
begin
assign(f,s);
rewrite(f);
write(f,mas);
close(f);
end;

procedure print_array(mas:main);
var i,j:byte;
begin
for i:=1 to 10 do
begin
for j:=1 to 2 do
write(mas[i,j],' ');
writeln;
end;
end;

var mas:main; i,j:integer; b:boolean;
begin
clrscr;
read_array('d:\input.ini',mas);
print_array(mas);
b:=false;
for i:=1 to 9 do
for j:=i to 10 do
if sqrt(sqr(mas[i,1]-mas[j,1])+sqr(mas[i,2]-mas[j,2]))<r then
b:=true;
writeln;
writeln;
if b=false then
begin
for i:=1 to 10 do
begin
if mas[i,1]<0 then
mas[i,1]:=0;
inc(mas[i,2],r);
writeln(mas[i,1],' ',mas[i,2]);
end;
end;

write_array('d:\output.ini',mas);
readln;
end.
volvo
Bokul,
var f: file of main;
далеко не то же самое, что
var f: text;


Кроме того:
if b=false then begin
for i:=1 to 10 do begin

if mas[i,1]<0 then begin { <--- Begin забыл }
mas[i,1]:=0;
inc(mas[i,2],r);
end; { <--- и End тоже }
writeln(mas[i,1],' ',mas[i,2]);

end;
end;
Bokul
volvo, не увидел unsure.gif , сейчас исправлю.
Bokul
Цитата
if mas[i,1]<0 then begin { <--- Begin забыл }
mas[i,1]:=0;
inc(mas[i,2],r);
end; { <--- и End тоже }
{ <--- Begin забыл }

А здесь и не надо Begin - ординату в любом случае надо увеличивать.

Вот процедури считования и записи для текстових файлов:
procedure read_array(s:string; var mas:main);
var f:text; buf1,buf2:string; code,i,j:byte;
begin
assign(f,s);
reset(f);
buf2:='';
for i:=1 to 10 do
begin
readln(f,buf1);
for j:=1 to length(buf1) do
begin
if buf1[j]=' ' then
begin
val(buf2,mas[i,1],code);
buf2:='';
end
else
buf2:=buf2+buf1[j];
if j=length(buf1) then
begin
val(buf2,mas[i,2],code);
buf2:='';
end;
end;
buf1:='';
end;
close(f);
end;

procedure write_array(s:string; mas:main);
var f:text; str1,str2:string; i:byte;
begin
assign(f,s);
rewrite(f);
append(f);
for i:=1 to 10 do
begin
str(mas[i,1],str1);
str(mas[i,2],str2);
writeln(f,str1+' ',str2);
end;
close(f);

end;
volvo
Цитата(Bokul @ 22.06.2006 20:15)
А здесь и не надо Begin - ординату в любом случае надо увеличивать.
Правда? Тогда, как ты объяснишь вот это:
Цитата(Задание)
Если нет ни одной пары точек, расстояние между которыми меньше заданной величины R, заменить на нуль в матрице Р все отрицательные абсциссы точек, увеличив ординаты этих точек на R.
Заметь, не "увеличив ординаты ВСЕХ точек на R.", а именно ЭТИХ точек...
Bokul
Цитата
а именно ЭТИХ точек...

Опять моя невнимательность проявляется...
Roman1
Спасибо большое!) код Bokul рабочий? ещё не компилил...
Bokul
Цитата
код Bokul рабочий? ещё не компилил...


Вот рабочий
uses crt;
const r=-10;
type
main=array[1..10,1..2]of integer;


procedure read_array(s:string; var mas:main);
var f:text; buf1,buf2:string; code,i,j:byte;
begin
assign(f,s);
reset(f);
buf2:='';
for i:=1 to 10 do
begin
readln(f,buf1);
for j:=1 to length(buf1) do
begin
if buf1[j]=' ' then
begin
val(buf2,mas[i,1],code);
buf2:='';
end
else
buf2:=buf2+buf1[j];
if j=length(buf1) then
begin
val(buf2,mas[i,2],code);
buf2:='';
end;
end;
buf1:='';
end;
close(f);
end;

procedure write_array(s:string; mas:main);
var f:text; str1,str2:string; i:byte;
begin
assign(f,s);
rewrite(f);
append(f);
for i:=1 to 10 do
begin
str(mas[i,1],str1);
str(mas[i,2],str2);
writeln(f,str1+' ',str2);
end;
close(f);

end;


procedure print_array(mas:main);
var i,j:byte;
begin
for i:=1 to 10 do
begin
for j:=1 to 2 do
write(mas[i,j],' ');
writeln;
end;
end;

var mas:main; i,j:integer; b:boolean;
begin
clrscr;
read_array('d:\input.ini',mas);
print_array(mas);
b:=false;
for i:=1 to 9 do
for j:=i to 10 do
if sqrt(sqr(mas[i,1]-mas[j,1])+sqr(mas[i,2]-mas[j,2]))<r then
b:=true;
writeln;
writeln;
if b=false then
begin
for i:=1 to 10 do
begin
if mas[i,1]<0 then
begin
mas[i,1]:=0;
inc(mas[i,2],r);
end;
writeln(mas[i,1],' ',mas[i,2]);
end;
end;

write_array('d:\output.ini',mas);
readln;
end.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.