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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.80
angelka
0 / 0 / 0
Регистрация: 24.10.2009
Сообщений: 9
28.02.2011, 19:40     Разработать программу для нахождения пары самых удаленных друг от друга точек #1
N точек на плоскости заданы своими координатами, значения которых формируются случайным образом. Разработать программу для нахождения пары самых удаленных друг от друга точек.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.02.2011, 19:40     Разработать программу для нахождения пары самых удаленных друг от друга точек
Посмотрите здесь:

найти две наиболее удаленных друг от друга точки (множество точек задано на плоскости) C++
C++ Число вершин, удаленных от пары вершин по кротчайшим маршрутам каждой из следующих длин: 1, 2, 3 и т.д., для каждой пары вершин.
C++ Найти номера наиболее и наименее удаленных друг от друга точек
C++ Задан массив точек. Найти номера наиболее и наименее удаленных друг от друга точек.
C++ пары целых чисел, делящиеся друг на друга
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
28.02.2011, 20:12     Разработать программу для нахождения пары самых удаленных друг от друга точек #2
Полный перебор. Считаете расстояние между всеми точками и ищите максимальное из них.
lemegeton
 Аватар для lemegeton
2909 / 1338 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
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;
}
igorrr37
 Аватар для igorrr37
1593 / 1221 / 118
Регистрация: 21.12.2010
Сообщений: 1,868
Записей в блоге: 7
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;
}
Yandex
Объявления
28.02.2011, 20:46     Разработать программу для нахождения пары самых удаленных друг от друга точек
Ответ Создать тему
Опции темы

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