Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 11.10.2017
Сообщений: 3

Даны координаты четырех попарно различных точек плоскости

11.10.2017, 06:58. Показов 2259. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Даны координаты четырех попарно различных точек плоскости.
a)Найти ту из них, которая ближе к началу координат.
b)Найти ту из них, которая дальше от начала координат.
Написал длинный код, в основном для красоты. НО
Во-первых, я так до конца и не понял, что такое четыре попарно различные точки.
Во-вторых, хочу увидеть максимально правильный и не длинный код, который будет делать то же самое.
В третьих, желательно объяснить, что и как работает (отсылка во второй пункт).
Потому что я новичок и не особо знаю какие то скрытые Паскальные функции и т.д.
Кому не сложно.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
program q;
 
var
  A: array [1..4, 1..2] of real; S: array [1..4, 1..2] of string;
  minmax, n: real;
  number, j, i, z, x: integer;
 
begin
  s[1, 1] := 'x1';
  s[1, 2] := 'y1';
  s[2, 1] := 'x2';
  s[2, 2] := 'y2';
  s[3, 1] := 'x3';
  s[3, 2] := 'y3';
  s[4, 1] := 'x4';
  s[4, 2] := 'y4';
  for i := 1 to 4 do
    for j := 1 to 2 do
    begin
      write('Введите ', S[i, j], ' координату.');
      readln(n);
      A[i, j] := n;
      if minmax < n then
        minmax := sqr(n);
    end;
  j := 0;
  for i := 1 to 4 do
    A[i, 1] := sqrt(sqr(A[i, 1]) + sqr(A[i, 2]));
  for i := 1 to 4 do 
  begin
    if A[i, 1] < minmax then begin
      minmax := a[i, 1];
      number := i;
    end
    else 
    if (A[i, 1] = minmax) and (j = 0) then 
    begin
      j := 1;
      n := i;
    end
      else 
    if (A[i, 1] = minmax) and (j = 1) then 
    begin
      j := 2;
      z := i;
    end
        else 
    if (A[i, 1] = minmax) and (j = 2) then
    begin
      j := 3;
      x := i;
    end;
  end;
  writeln();
  if j = 0 then
    write(number, ' точка - самая ближняя к началу координат, расстояние от точки до начала координат равно ', minmax)
  else 
  if j = 1 then
    write(number, ' ', n, ' точки - самые ближние к началу координат, расстояние от точек до начала координат равно ', minmax)
  else
  if j = 2 then 
    write(number, ' ', n, ' ', z, ' точки - самые ближние к началу координат, расстояние от точек до начала координат равно ', minmax)
  else
  if j = 3 then
    write(number, ' ', n, ' ', z, ' ', x, ' точки - самые ближние к началу координат, расстояние от точек до начала координат равно ', minmax);
  minmax := 0;
  for i := 1 to 4 do 
  begin
    if A[i, 1] > minmax then begin
      minmax := a[i, 1];
      number := i;
      j:=0;
    end
    else 
    if (A[i, 1] = minmax) and (j = 0) then 
    begin
      j := 1;
      n := i;
    end
      else 
    if (A[i, 1] = minmax) and (j = 1) then 
    begin
      j := 2;
      z := i;
    end
        else 
    if (A[i, 1] = minmax) and (j = 2) then
    begin
      j := 3;
      x := i;
    end;
  end;
  writeln();
  if j = 0 then
    write(number, ' точка - самая дальняя от начала координат, расстояние от точки до начала координат равно ', minmax)
  else 
  if j = 1 then
    write(number, ' ', n, ' точки - самые дальние от начала координат, расстояние от точек до начала координат равно ', minmax)
  else
  if j = 2 then 
    write(number, ' ', n, ' ', z, ' точки - самые дальние от начала координат, расстояние от точек до начала координат равно ', minmax)
  else
  if j = 3 then
    write(number, ' ', n, ' ', z, ' ', x, ' точки - самые дальние от начала координат, расстояние от точек до начала координат равно ', minmax)
end.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.10.2017, 06:58
Ответы с готовыми решениями:

У квадрата ABCD на плоскости известны координаты двух противоположных вершин - точек A и C. Найти координаты точек B и
У квадрата ABCD на плоскости известны координаты двух противоположных вершин - точек A и C. Найти координаты точек B и D. Расположение...

Даны координаты четырех точек на плоскости. Найти отрезок минимальной длины. Вычисление расстояния между двумя
Даны координаты четырех точек на плоскости. Найти отрезок минимальной длины. Вычисление расстояния между двумя точками оформить в виде...

Даны координаты четырёх точек x1, y1, x2, y2, x3, y3, x4, y4
Задание такое: Даны координаты четырёх точек x1, y1, x2, y2, x3, y3, x4, y4. Найти наименьший из периметров треугольников, вершины которых...

1
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
11.10.2017, 11:06
Цитата Сообщение от ZlOun Посмотреть сообщение
что такое четыре попарно различные точки.
Это значит что у них разные координаты, никакие 2 точки не совпадают.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
const n=4;
type point=record
           x,y:integer;
           end;
var t:array[1..n] of point;
    imn,imx,k:byte;
begin
writeln('Введите координаты ',n,' попарно различных точек');
for var i:=1 to n do
 begin
  if i=1 then
   begin
    write('x1=');
    readln(t[i].x);
    write('y1=');
    readln(t[i].y);
   end
  else 
   repeat
    write('x',i,'=');
    readln(t[i].x);
    write('y',i,'=');
    readln(t[i].y);
    k:=0;
    for var j:=1 to i-1 do
    if(t[j].x=t[i].x)and(t[j].y=t[i].y)then
     begin
      k:=1;
      break;
     end;
    if k=1 then writeln('Такая точка уже была, введите другие координаты');
   until k=0;
  end;
 imn:=1;
 imx:=1;
 for var i:=2 to n do
 if sqr(t[i].x)+sqr(t[i].y)<sqr(t[imn].x)+sqr(t[imn].y)then imn:=i
 else if sqr(t[i].x)+sqr(t[i].y)>sqr(t[imx].x)+sqr(t[imx].y)then imx:=i;
 writeln('Ближе к началу координат точка ',imn,' расстояние=',sqrt(sqr(t[imn].x)+sqr(t[imn].y)):0:2);
 writeln('Дальше от начала координат точка ',imx,' расстояние=',sqrt(sqr(t[imx].x)+sqr(t[imx].y)):0:2);
 end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.10.2017, 11:06
Помогаю со студенческими работами здесь

Даны координаты четырёх точек А1, А2, A3 и A4. Составьте уравнения
Даны координаты четырёх точек A1(10; 9; 6), A2(1; 8; 2), A3(9; 8; 2), A4(7; 10; 3).. Составьте уравнения: а) плоскости А1А2A3; б)...

Даны координаты N точек на плоскости. найти номера всех пар точек расстояние между которыми наибольшее
Даны координаты N точек на плоскости. найти номера всех пар точек расстояние между которыми наибольшее.

В массиве даны координаты n точек плоскости
Решите плиззз В одномерном массиве с четным количеством элементов (2N) находящиеся координаты N точек плоскости.Они распологаются в...

Даны координаты двух точек на плоскости, описать их как записи,
Даны координаты двух точек на плоскости, описать их как записи, которые являются концами диагонали прямоугольника со сторонами...

Как это выполнить? Даны координаты точек х и у, лежащих на плоскости
Срочно помогите это выполнить!!!!! Даны координаты точек x и y, лежащих на плоскости (сфор-правлены в виде двухмерного массива)....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Номеклатура. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru