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

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

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

> площадь и преиметр многоугольника
Богдан))(
сообщение 18.02.2010 23:24
Сообщение #1





Группа: Пользователи
Сообщений: 3
Пол: Мужской

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


многоугольник задан на плоскости координатами вершин в порядке обхода. найти его площадь и периметр. подскажите где ощибка!!

program mnog;
type point=record
x,y:integer;
end;
var p:array[1..1000] of point;
n,i:integer;sum,per:extended;f3:text;
function storona(a,b,c,d:integer):real;
begin
storona:=sqrt(sqr(c-a)+sqr(d-b) ;
end;
begin

assign(f3,'input.txt');
reset(f3);
readln(f3,n);
for i:=1 to n do
readln(f3,p[i].x,p[i].y);
close(f3);
per:=0;
sum:=0;
for i:=3 to n do
readln(f3,p[i].x,p[i].y);
close(f3);
per:=0;
sum:=0;
for i:=3 to n do
sum:=sum+ 0.5*abs((p[i-1].x-p[1].x)*(p[i].y-p[1].y)-(p[i].x-p[1].x)*(p[i-1].y-p[1].y));

for i:=2 to n do
per:=per+storona(p[i-1].x,p[i-1].y,p[i].x,p[i].y);
per:=per+storona(p[1].x,p[1].y,p[n].x,p[n].y);
writeln(sum);
writeln(per);
readln;readln;end.


Тэги!! Lapp
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
Богдан))(
сообщение 19.02.2010 20:21
Сообщение #2





Группа: Пользователи
Сообщений: 3
Пол: Мужской

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


извини. не подумал, что у тебя плохое зрение!!
кстати, нашел ошибку.
вот правильная прога
может кому интересно


Цитата
program mnog;
type point=record
x,y:real;
end;
var p:array[1..1000] of point;
n,i:integer;
sum,per:real;
f3:text;
function storona(a,b,c,d:real):real;
begin storona:=sqrt(sqr(c-a)+sqr(d-b));
end;
begin
assign(f3,'input.txt');
reset(f3);
readln(f3,n);
for i:=1 to n do readln(f3,p[i].x,p[i].y);
close(f3);
per:=0;sum:=0;

for i:=3 to n do {считает площадь}
sum:=sum+ 0.5*abs((p[i-1].x-p[1].x)*(p[i].y-p[1].y)-(p[i].x-p[1].x)*(p[i-1].y-p[1].y));

for i:=2 to n do {считает периметр}
per:=per+storona(p[i-1].x,p[i-1].y,p[i].x,p[i].y);
per:=per+storona(p[1].x,p[1].y,p[n].x,p[n].y);

assign(f3,'output.txt');
rewrite(f3);
writeln(f3,sum:10:10);
writeln(f3,per:10:10);
close(f3);
end.


что касается чертежа, то его можно найти в любом учебнике по математике за 9 класс!!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Lapp
сообщение 19.02.2010 23:45
Сообщение #3


Уникум
*******

Группа: Модераторы
Сообщений: 6 823
Пол: Мужской
Реальное имя: Лопáрь (Андрей)

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


Цитата(Богдан))( @ 19.02.2010 20:21) *
извини. не подумал, что у тебя плохое зрение!!
кстати, нашел ошибку.
вот правильная прога
может кому интересно
Никому не интересно, уверяю тебя.

Цитата
что касается чертежа, то его можно найти в любом учебнике по математике за 9 класс!!
И все сразу побежали и стали искать любой учебник за 9 класс. А те счастливчики, которые нашли - они сидят и жадно листают его, чтобы только угодить милейшему Богдану))(..

М
Богдан))(, прочти Правила Форума и в следующий раз выполняй их.



--------------------
я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


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

 



- Текстовая версия 12.08.2025 8:52
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"