Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.80
angelka
0 / 0 / 1
Регистрация: 24.10.2009
Сообщений: 9
#1

Разработать программу для нахождения пары самых удаленных друг от друга точек - C++

28.02.2011, 19:40. Просмотров 1650. Ответов 3
Метки нет (Все метки)

N точек на плоскости заданы своими координатами, значения которых формируются случайным образом. Разработать программу для нахождения пары самых удаленных друг от друга точек.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.02.2011, 19:40
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Разработать программу для нахождения пары самых удаленных друг от друга точек (C++):

Разработать программу для нахождения пары самых удаленных друг от друга точек
N точек на плоскости заданы своими координатами, значения которых формируются...

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

Задан массив точек. Найти номера наиболее и наименее удаленных друг от друга точек.
Условие задачи: В одномерном массиве с четным количеством элементов (2N)...

Найти номера наиболее и наименее удаленных друг от друга точек
В одномерном массиве с четным количеством элементов (2N) находятся координаты N...

найти две наиболее удаленных друг от друга точки (множество точек задано на плоскости)
Помогите, пожалуйста, написать программу на С++, используя структуру point для...

Найти две наиболее удаленных друг от друга точки
Структуры: I. Решить задачу, используя структуру point для хранения координат...

3
silent_1991
Эксперт С++
5007 / 3067 / 270
Регистрация: 11.11.2009
Сообщений: 7,043
Завершенные тесты: 1
28.02.2011, 20:12 #2
Полный перебор. Считаете расстояние между всеми точками и ищите максимальное из них.
0
lemegeton
2933 / 1362 / 467
Регистрация: 29.11.2010
Сообщений: 2,725
28.02.2011, 20:42 #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
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#include <cstdio>
#include <cmath>
#include <ctime>
#include <cstdlib>
#include <vector>
 
struct Point {
  int x, y;
  Point(int x_, int y_) : x(x_), y(y_) {}
};
 
inline float Distance(const Point &a, const Point &b) {
  return sqrt(pow(a.x - b.x, 2.) + pow(a.y - b.y, 2.));
}
 
int main(int argc, char *argv[]) {
  srand(time(NULL));
  int number_of_points = 15 + rand() % 6;
  std::vector<Point> points;
  for (int i = 0; i < number_of_points; ++i) {
    Point new_point(rand() % 100, rand() % 100);
    printf("(%d, %d) ", new_point.x, new_point.y);
    points.push_back(Point(new_point));
  }
  printf("\n");
 
  Point max_a = points[0], max_b = points[1];
  float max_distance;
  for (int i = 0; i < number_of_points - 1; ++i)
    for (int j = i; j < number_of_points; ++j) {
      float distance = Distance(points[i], points[j]);
      if (distance > max_distance) {
        max_a = points[i];
        max_b = points[j];
        max_distance = distance;
      }
    }
 
  printf("Max distance (%d, %d) - (%d, %d) = %f\n", max_a.x, max_a.y,
         max_b.x, max_b.y, max_distance);
  return 0;
}
0
igorrr37
1863 / 1481 / 749
Регистрация: 21.12.2010
Сообщений: 2,473
Записей в блоге: 11
28.02.2011, 20:46 #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
24
25
26
27
28
29
30
31
32
33
34
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#include<math.h>
 
int main(){
    int n, i, j, maxi1, maxi2;
    double maxDist=-1, tmpDist;
    fputs("n= ", stdout);
    scanf("%d", &n);
    int* xs=(int*)malloc(n*sizeof(int));
    int* ys=(int*)malloc(n*sizeof(int));
    srand(time(NULL));
    for(i=0; i<n; i++){
        xs[i]=rand()%10-5;
        ys[i]=rand()%10-5;
        printf("x= %d, y= %d\n", xs[i], ys[i]);
    }
    for(i=0; i<n; i++){
        for(j=i+1; j<n; j++){
            tmpDist=sqrt(pow(xs[i]-xs[j], 2)+pow(ys[i]-ys[j], 2));
            /*printf("tmpDist= %f\n", tmpDist);*/
            if(tmpDist>maxDist){
                maxDist=tmpDist;
                maxi1=i;
                maxi2=j;
            }
        }
    }
    printf("(%d, %d), (%d, %d), dist=%f", xs[maxi1], ys[maxi1], xs[maxi2], ys[maxi2], maxDist);
    free(xs);
    free(ys);
    return 0;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.02.2011, 20:46
Привет! Вот еще темы с решениями:

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

На шахматной доске даются координаты 8 ферзей. Узнать пары, которые бьют друг друга
Дана шахматная доска 8х8. На вход подаются координаты местоположения 8 ферзей....

Нарисовать заданное количество точек окружности, равноудалённых друг от друга
Ребят, помогите! Делаю исследовательскую работу по математике и встал в ступор...

Поиск точек в массиве которые находятся на максимальном расстоянии друг от друга
Здравствуйте, Есть массив чисел например 0 и 1, нужно в этом массиве найти...


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

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

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