Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 28.05.2013
Сообщений: 6
1

Расстояние между точками

28.05.2013, 19:25. Просмотров 1024. Ответов 7
Метки нет (Все метки)

задание: дано n точек определить номера точек которые имеют максимальное и минимальное расстояние между точками.
Когда вводил n=3 и координаты точке, программа работала неправильно, посмотрите ,пожалуйста, где может быть ошибка.
мой код:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdio.h>
#include <math.h.>
#include <stdlib.h>
void main()
{fload a[999],b[999];
int i,j,k1,k2,k3,k4;
fload max,l,min;
printf("Vvedi n");
scanf("%d",&n);
printf("vvedi x u y");
for (i=0;i<=n-1;i++)
scanf("%f %f", &a[i],&b[i]);
l=sqrt(pow(a[1]-a[0],2)+pow(b[1]-b[0],2));
max=l;min=l;
 
for(i=0;i<=n-2;i++)
for (j=0;j<=n-1;j++)
{ l=sqrt(pow(a[i]-a[j],2)+pow(b[i]-b[j],2));
if (l<=min) {k1=i;k2=j;};
if (l>=max) {k3=i;k4=j;}}
 
printf ("%d %d %d %d",k1,k2,k3,k4);
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.05.2013, 19:25
Ответы с готовыми решениями:

Расстояние между двумя множествами точек - это расстояние между наиболее близко расположенными точками этих
1. Расстояние между двумя множествами точек - это расстояние между наиболее близко расположенными...

Найти расстояние от начала координат до каждой точки и расстояние между точками
задача на С++ На плоскости заданы точки своими координатами. Найти расстояние от начала координат...

Расстояние между точками x0 y0 x1 y1
Всем привет, не могу понять в чем проблема программы: Найти расстояние между двумя точками...

Расстояние между 2-мя точками.
Попробовал сам, но она не выполняется, пишет ошибки при вычислении корня. Задача в следующем:...

7
211 / 130 / 28
Регистрация: 20.03.2009
Сообщений: 1,120
Записей в блоге: 16
28.05.2013, 19:52 2
j надо начинать считать не с нуля, а с i+1, чтобы не было случая, когда вы смотрите расстояние между двумя одинаковыми точками. И тип должен быть не fload, а float, если это не опечатка.
1
136 / 128 / 59
Регистрация: 13.12.2012
Сообщений: 293
28.05.2013, 19:53 3
C++
1
int i,j,k1=0,k2=1,k3=0,k4=1;
C++
1
2
3
4
for (j=i+1;j<=n-1;j++)
{ l=sqrt(pow(a[i]-a[j],2)+pow(b[i]-b[j],2));
if (l<=min) {min=l;k1=i;k2=j;};
if (l>=max) {max=l;k3=i;k4=j;}}
1
0 / 0 / 0
Регистрация: 28.05.2013
Сообщений: 6
28.05.2013, 20:09  [ТС] 4
Исправила.Вроде все хорошо
вот код:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdio.h>
 #include <math.h>
 #include <stdlib.h>
 void main()
 {float a[999],b[999];
 int n,i,j,k1,k2,k3,k4;
 float max,l,min;
 printf("Vvedi n");
 scanf("%d",&n);
 printf("vvedi x u y");
 for (i=0;i<=n-1;i++)
 scanf("%f %f", &a[i],&b[i]);
 l=sqrt(pow(a[1]-a[0],2)+pow(b[1]-b[0],2));
 max=l;min=l;
 
 for(i=0;i<=n-2;i++)
 for (j=i+1;j<=n-1;j++)
 { l=sqrt(pow(a[i]-a[j],2)+pow(b[i]-b[j],2));
 if (l<=min) {min=l;k1=i;k2=j;};
 if (l>=max) {max=l;k3=i;k4=j;}}
 
 printf ("%d %d %d %d",k1,k2,k3,k4);
 }
0
413 / 409 / 95
Регистрация: 06.10.2011
Сообщений: 832
28.05.2013, 20:14 5
C++
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
#include <iostream>
#include <vector>
#include <limits>
#include <cmath>
 
using namespace std;
 
typedef pair<double, double> point;
 
double distance(const point &a, const point &b)
{ return sqrt( pow(a.first - b.first, 2.0) + pow(a.second - b.second, 2.0) ); }
 
ostream& operator << (ostream &os, const point &p)
{ return os << '(' << p.first << ", " << p.second << ')'; }
 
int main()
{
    vector<point> points { {0, 0}, {5, 5}, {7, 7} };
    double min_distance = numeric_limits<double>::max(),
           max_distance = numeric_limits<double>::min();
 
    pair<int, int> min {-1, -1}, max {-1, -1};
 
    for (auto i = 0; i != points.size(); i++)
        for (auto j = i + 1; j != points.size(); j++) {
            double distance_at = distance( points[i], points[j] );
            if ( distance_at > max_distance ) {
                max_distance = distance_at;
                max = {i, j};
            }
            if ( distance_at < min_distance ) {
                min_distance = distance_at;
                min = {i, j};
            }
        }
    if ( min.first != -1 && max.first != -1 )
        cout << "min distance is " << min_distance << ", between " << points[min.first] << " and " << points[min.second]
             << "\nmax distance is " << max_distance << ", between " << points[max.first] << " and " << points[max.second];
    return 0;
}
0
0 / 0 / 0
Регистрация: 28.05.2013
Сообщений: 6
28.05.2013, 20:19  [ТС] 6
Думаю тему можно закрыть.
0
0 / 0 / 0
Регистрация: 28.05.2013
Сообщений: 6
30.05.2013, 23:45  [ТС] 7
Ребят ещё вопрос. Показала код преподу, препод сказал что программа при нектрых точках будет работать неправильно, поищите ошибку плиз , вот код :
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <stdio.h>
 #include <math.h>
 #include <stdlib.h>
 void main()
 {float a[999],b[999];
 int n,i,j,k1,k2,k3,k4;
 float max,l,min;
 printf("Vvedi n");
 scanf("%d",&n);
 printf("vvedi x u y");
 for (i=0;i<=n-1;i++)
 scanf("%f %f", &a[i],&b[i]);
 l=sqrt(pow(a[1]-a[0],2)+pow(b[1]-b[0],2));
 max=l;min=l;
 
 for(i=0;i<=n-2;i++)
 for (j=i+1;j<=n-1;j++)
 { l=sqrt(pow(a[i]-a[j],2)+pow(b[i]-b[j],2));
 if (l>=max) {k1=i;k2=j;max=l;};
 if (l<=min) {k3=i;k4=j;min=l;};
}
 
 printf ("max =%d %d  \n min =%d %d",k1,k2,k3,k4);
 }
Добавлено через 4 минуты
Тема Up. Как сделать чтобы программа выдавала 3 точки с минимальным расстоянием?

Добавлено через 16 минут
тема Up!
0
Форумчанин
Эксперт CЭксперт С++
8159 / 5007 / 1436
Регистрация: 29.11.2010
Сообщений: 13,458
31.05.2013, 02:51 8
tatiana2472, вы б хоть потрудились отступы или пробелы расставить, код трудночитаем.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
31.05.2013, 02:51

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Расстояние между двумя точками
1. Напишите функцию distance, которая вычисляет расстояние между двумя точками (x1, y1) и (x2, y2)....

Вычислить расстояние между точками
Здраствуйте, нужно перевести программу из Pascal в С++, завтра здача и срочно нужен код программы...

Расстояние между двумя точками
Найти расстояние между двумя точками (x1, y1) и (x2, y2) Формат входных данных Одна...

Найти наибольшее расстояние между точками
#include &lt;cstdlib&gt; #include &lt;iostream&gt; #include &lt;Math.h&gt; using namespace std; double...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.