Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
tatiana2472
0 / 0 / 0
Регистрация: 28.05.2013
Сообщений: 6
28.05.2013, 19:25     Расстояние между точками #1
задание: дано 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);
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Гром
 Аватар для Гром
199 / 118 / 10
Регистрация: 20.03.2009
Сообщений: 1,075
Записей в блоге: 15
28.05.2013, 19:52     Расстояние между точками #2
j надо начинать считать не с нуля, а с i+1, чтобы не было случая, когда вы смотрите расстояние между двумя одинаковыми точками. И тип должен быть не fload, а float, если это не опечатка.
ViktorKozlov
133 / 125 / 2
Регистрация: 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;}}
tatiana2472
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);
 }
Olivеr
 Аватар для Olivеr
411 / 407 / 13
Регистрация: 06.10.2011
Сообщений: 830
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;
}
tatiana2472
0 / 0 / 0
Регистрация: 28.05.2013
Сообщений: 6
28.05.2013, 20:19  [ТС]     Расстояние между точками #6
Думаю тему можно закрыть.
tatiana2472
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!
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.05.2013, 02:51     Расстояние между точками
Еще ссылки по теме:

Расстояние между точками x0 y0 x1 y1 C++
Определите расстояние между двумя введенными точками C++
C++ Расстояние между двумя точками

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

Или воспользуйтесь поиском по форуму:
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4920 / 2663 / 243
Регистрация: 29.11.2010
Сообщений: 7,416
31.05.2013, 02:51     Расстояние между точками #8
tatiana2472, вы б хоть потрудились отступы или пробелы расставить, код трудночитаем.
Yandex
Объявления
31.05.2013, 02:51     Расстояние между точками
Ответ Создать тему
Опции темы

Текущее время: 00:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru