![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() |
kristianu |
![]()
Сообщение
#1
|
Новичок ![]() Группа: Пользователи Сообщений: 11 Пол: Мужской Реальное имя: Александр Репутация: ![]() ![]() ![]() |
Задача: Даны 4 точки на плоскости (x1,y1),...,(x4,y4).Определить, образуют ли эти точки выпуклый четырехугольник.
Задача может и где-то и звучала, но я ищу более "эллигантный" подход. О критерии выпуклости помню только, то что векторное произведение векторов сторон должно быть одного знака...От этого и исходил в данном коде(еще, кстати не приятно, ведь, если мне даны только координаты (X,Y), то векторное произведение равно X1*Y2+X2*Y1 ??? ): Код Program Lab9; Uses CRT; Procedure NewVector(Var a1,b1,a2,b2:integer); begin a1:=a2-a1; b1:=b2-b1; end; Function VectPr(a1,b1,a2,b2:integer):integer; begin VectPr:=a1*b2+a2*b1; end; Var x1,y1,x2,y2,x3,y3,x4,y4:integer; Const Text='vvedite coordinati X,Y(cherez probel) tochki#'; Begin ClrScr; Textcolor(yellow); GotoXY(1,3); Writeln('Program for Lab9'); writeln; Writeln(Text,'1:'); readln(x1,y1); Writeln(Text,'2:'); readln(x2,y2); NewVector(x1,y1,x2,y2); Writeln(Text,'3:'); readln(x3,y3); NewVector(x2,y2,x3,y3); Writeln(Text,'4:'); readln(x4,y4); NewVector(x3,y3,x4,y4); NewVector(x4,y4,x1,y1); TextColor(white); Writeln; if VectPr(x1,y1,x2,y2)>0 Then if (VectPr(x3,y3,x4,y4)>0) AND (VectPr(x4,y4,x1,y1)>0) Then if VectPr(x1,y1,x2,y2)>0 Then Writeln('chetirehugolnik vipucliy') else Writeln('chetirehugolnik ne vipucliy') else Writeln('chetirehugolnik ne vipucliy') else if (VectPr(x3,y3,x4,y4)<0) AND (VectPr(x4,y4,x1,y1)<0) Then if VectPr(x1,y1,x2,y2)<0 Then Writeln('chetirehugolnik vipucliy') else Writeln('chetirehugolnik ne vipucliy') else Writeln('chetirehugolnik ne vipucliy'); readln; Вообщем помогите мне найти, более лаконичное решение, или хотя бы какие есть еще критерии выпуклости.... ![]() Сообщение отредактировано: volvo - 8.12.2005 18:35 |
![]() ![]() |
volvo |
![]()
Сообщение
#2
|
Гость ![]() |
Цитата Ищем более лаконичное решение Меняй название, или тема перемещается в корзину... Правила для тебя никто не отменял. ![]() Цитата Задача может и где-то и звучала, но я ищу более "эллигантный" подход. То есть ты, даже не смотря на задачу, и на ее решение, уже утверждаешь, что она НЕэлегантна, и заведомо написана некрасиво? Интересный подход... Поиском пользуйся иногда ! |
kristianu |
![]()
Сообщение
#3
|
Новичок ![]() Группа: Пользователи Сообщений: 11 Пол: Мужской Реальное имя: Александр Репутация: ![]() ![]() ![]() |
Цитата Меняй название, или тема перемещается в корзину... Правила для тебя никто не отменял. Не злись, если бы я знал еще, как это сделать ![]() Цитата "эллигантный" подход По сравнению с моим!!! поиском пользовался и ничего путного, возможно не правильно искал ![]() To: volvo Если можешь дай ссылочку, на схожую задачу, хотя суть темы была в преобразовании моего решения... |
volvo |
![]()
Сообщение
#4
|
Гость ![]() |
Цитата суть темы была в преобразовании моего решения... Ну, тогда тебе надо бы ввести массивы (с элементом - записью Type
Vector = Record
X, Y: Integer;
End;
), и твоя программа сразу уменьшится в 4 раза...P.S. Первое сообщение темы - кнопка "Правка" - и меняй название... |
kristianu |
![]()
Сообщение
#5
|
Новичок ![]() Группа: Пользователи Сообщений: 11 Пол: Мужской Реальное имя: Александр Репутация: ![]() ![]() ![]() |
Цитата P.S. Первое сообщение темы - кнопка "Правка" - и меняй название... Так проблема в том что ее нет(я знаю, что она должна находится в правом нижнем углу ![]() Цитата твоя программа сразу уменьшится в 4 раза... В 4 раза она не сократится, у меня был такой вариант, там свои траблы... |
volvo |
![]()
Сообщение
#6
|
Гость ![]() |
А если я ее сокращу больше, чем в 4 раза?
![]() Приведи тот вариант, который у тебя был... |
kristianu |
![]()
Сообщение
#7
|
Новичок ![]() Группа: Пользователи Сообщений: 11 Пол: Мужской Реальное имя: Александр Репутация: ![]() ![]() ![]() |
Хорошие люди мне подсказали, что можно через диагонали сделать, вот это будет меньше...чуть позже покажу наброски...
volvo, если можешь сам измени название темы.... ![]() |
volvo |
![]()
Сообщение
#8
|
Гость ![]() |
kristianu,
а ты прогонял свою программу? Она же у тебя не работает вообще !!! Ты ее сначала приведи в рабочее состояние, а потом улучшай. Доказательство: Цитата(Console) vvedite coordinati X,Y(cherez probel) tochki#1: 2 2 vvedite coordinati X,Y(cherez probel) tochki#2: 3 5 vvedite coordinati X,Y(cherez probel) tochki#3: 5 4 vvedite coordinati X,Y(cherez probel) tochki#4: 4 1 chetirehugolnik ne vipucliy ![]() |
kristianu |
![]()
Сообщение
#9
|
Новичок ![]() Группа: Пользователи Сообщений: 11 Пол: Мужской Реальное имя: Александр Репутация: ![]() ![]() ![]() |
Хм трабла...
![]() ![]() |
kristianu |
![]()
Сообщение
#10
|
Новичок ![]() Группа: Пользователи Сообщений: 11 Пол: Мужской Реальное имя: Александр Репутация: ![]() ![]() ![]() |
Быстро нашел!
![]()
Function VectPr(a1,b1,a2,b2:integer):integer;
begin
VectPr:=a1*b2-a2*b1; {+\-}
end;
Теперь должно работать ![]() |
volvo |
![]()
Сообщение
#11
|
Гость ![]() |
kristianu, я думаю, так будет поэлегантней?
Program Lab9;
Uses CRT;
const
nPoints = 4;
type
TPoint = record
X, Y: integer;
end;
ArrType = Array[0 .. Pred(nPoints)] of TPoint;
Procedure CreateVector(Var a1, b1: Integer;
a2, b2: Integer);
Begin
a1 := a2 - a1; b1 := b2 - b1;
End;
Function Vector(A, B: TPoint): Integer;
Begin
Vector := B.X*A.Y - A.X*B.Y;
End;
var
Arr: ArrType;
Ok: Boolean;
i, pX, pY: Integer;
Begin
For i := 0 To Pred(nPoints) Do Begin
Write('Enter the #', i:2, ' point [X Y]: ');
ReadLn(Arr[i].X, Arr[i].Y);
If i = 0 Then Begin
pX := Arr[i].X; pY := Arr[i].Y;
End
Else
CreateVector(Arr[Pred(i)].X, Arr[Pred(i)].Y,
Arr[i].X, Arr[i].Y);
End;
CreateVector(Arr[Pred(nPoints)].X, Arr[Pred(nPoints)].Y,
pX, pY);
{$B+} { В принципе, можно убрать это было для отладки... Второй тоже }
Ok := True;
For i := 0 To Pred(nPoints) Do
Ok := Ok and (Vector(Arr[i], Arr[Succ(i) mod nPoints]) > 0);
{$B-}
if Ok Then Writeln('Yes') Else WriteLn('No');
ReadLn;
end.
|
kristianu |
![]()
Сообщение
#12
|
Новичок ![]() Группа: Пользователи Сообщений: 11 Пол: Мужской Реальное имя: Александр Репутация: ![]() ![]() ![]() |
To: volvo , красота....
![]() Но всеже не обещенные в 4 раза меньше ![]() Это как раз весьма элегантно ![]() |
![]() ![]() |
![]() |
Текстовая версия | 24.07.2025 14:33 |