помогите пожалуйста: Считать из текстового файла Beg.txt матрицу Р(2,10). Элементы столбцов соответственно абсцисса и ордината одной из десяти точек плоскости. Если нет ни одной пары точек, расстояние между которыми меньше заданной величины R, заменить на нуль в матрице Р все отрицательные абсциссы точек, увеличив ординаты этих точек на R. Результат записать в файл Rez.txt. Если получится, то сегодня
Bokul
22.06.2006 23:30
uses crt;
const r=-10;
type
main=array[1..10,1..2]of integer;
procedure read_array(s:string; var mas:main);
var f: fileof main;
begin
assign(f,s);
reset(f);
read(f,mas);
close(f);
end;
procedure write_array(s:string; mas:main);
var f:fileof main;
begin
assign(f,s);
rewrite(f);
write(f,mas);
close(f);
end;
procedure print_array(mas:main);
var i,j:byte;
beginfor i:=1to10dobeginfor j:=1to2do
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:=1to9dofor j:=i to10doif sqrt(sqr(mas[i,1]-mas[j,1])+sqr(mas[i,2]-mas[j,2]))<r then
b:=true;
writeln;
writeln;
if b=false thenbeginfor i:=1to10dobeginif mas[i,1]<0then
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
22.06.2006 23:33
Bokul,
var f: fileof main;
далеко не то же самое, что
var f: text;
Кроме того:
if b=false thenbeginfor i:=1to10dobeginif mas[i,1]<0thenbegin{ <--- Begin забыл }
mas[i,1]:=0;
inc(mas[i,2],r);
end; { <--- и End тоже }
writeln(mas[i,1],' ',mas[i,2]);
end;
end;
Bokul
22.06.2006 23:36
volvo, не увидел , сейчас исправлю.
Bokul
23.06.2006 0:15
Цитата
if mas[i,1]<0thenbegin{ <--- 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:=1to10dobegin
readln(f,buf1);
for j:=1to length(buf1) dobeginif buf1[j]=' 'thenbegin
val(buf2,mas[i,1],code);
buf2:='';
endelse
buf2:=buf2+buf1[j];
if j=length(buf1) thenbegin
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:=1to10dobegin
str(mas[i,1],str1);
str(mas[i,2],str2);
writeln(f,str1+' ',str2);
end;
close(f);
end;
volvo
23.06.2006 0:23
Цитата(Bokul @ 22.06.2006 20:15)
А здесь и не надо Begin - ординату в любом случае надо увеличивать.
Правда? Тогда, как ты объяснишь вот это:
Цитата(Задание)
Если нет ни одной пары точек, расстояние между которыми меньше заданной величины R, заменить на нуль в матрице Р все отрицательные абсциссы точек, увеличив ординаты этих точек на R.
Заметь, не "увеличив ординаты ВСЕХ точек на R.", а именно ЭТИХ точек...
Bokul
23.06.2006 0:35
Цитата
а именно ЭТИХ точек...
Опять моя невнимательность проявляется...
Roman1
23.06.2006 0:41
Спасибо большое!) код Bokul рабочий? ещё не компилил...
Bokul
23.06.2006 0:50
Цитата
код 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:=1to10dobegin
readln(f,buf1);
for j:=1to length(buf1) dobeginif buf1[j]=' 'thenbegin
val(buf2,mas[i,1],code);
buf2:='';
endelse
buf2:=buf2+buf1[j];
if j=length(buf1) thenbegin
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:=1to10dobegin
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;
beginfor i:=1to10dobeginfor j:=1to2do
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:=1to9dofor j:=i to10doif sqrt(sqr(mas[i,1]-mas[j,1])+sqr(mas[i,2]-mas[j,2]))<r then
b:=true;
writeln;
writeln;
if b=false thenbeginfor i:=1to10dobeginif mas[i,1]<0thenbegin
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.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.