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

Класс "Отрезок". Вычислить длину отрезка.

12.02.2012, 13:52. Показов 3503. Ответов 7
Метки нет (Все метки)

создать класс отрезок,чтобы также можно было вычислить длину отрезка
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.02.2012, 13:52
Ответы с готовыми решениями:

Создать класс "точка" и производный класс "отрезок"
Создать класс "точка" и производный класс "отрезок" ИСПОЛЬЗОВАТЬ КОНСТРУКТОРЫ И ДИСТРУКТОРЫ и к...

Класс "линия" наследуется классом "отрезок"
Помогите, пожалуйста, разобраться с лабораторной. Нужно создать базовый класс "линия": координаты...

Отрезок задан координатами своих концевых точек. Требуется вычислить длину этого отрезка
проваливает 3 тест Отрезок задан координатами своих концевых точек. Требуется вычислить длину...

Класс "Окружность" с данными центр и радиус окружности. Вычислить длину и площадь окружности.
Объявить класс и определить для него конструктор по умолчанию, конструктор инициализации....

7
Cандальная шляпа
42 / 42 / 36
Регистрация: 12.01.2012
Сообщений: 187
12.02.2012, 14:02 2
А поточнее, можно?
0
2015 / 1614 / 489
Регистрация: 31.05.2009
Сообщений: 3,005
12.02.2012, 22:15 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
43
44
#include <iostream>
#include <cmath>
 
//-----------------
struct point
{
  double x;
  double y;
  
  point(double x, double y)
    : x(x), 
      y(y)
  {
  }
};
 
//-----------------
class line_segment
{
  private:
    point a_;
    point b_;
    double len_;
 
  public:
    line_segment(const point& a, const point& b)
      : a_(a), 
        b_(b)
    {
      len_ = std::sqrt(std::pow(b.y - a.y, 2) + std::pow(b.x - a.x, 2));
    }
 
    double length() const
    {
      return len_;
    }
};
 
//-----------------
int main()
{
  line_segment obj(point(3, 5), point(5, 8));
  std::cout << obj.length() << std::endl; 
}
2
287 / 228 / 27
Регистрация: 13.06.2010
Сообщений: 744
24.02.2012, 17:13 4
Ну так давайте формулы / наработки. Или все делать за вас? Тут не стол заказов.
Цитата Сообщение от пацанчо Посмотреть сообщение
создать класс отрезок,чтобы также можно было вычислить длину отрезка
rangerx создал вам такой класс.

Цитата Сообщение от пацанчо Посмотреть сообщение
и это все?))
Это всё!
1
-6 / 0 / 0
Регистрация: 02.04.2011
Сообщений: 38
26.02.2012, 15:43  [ТС] 5
вот кое что накалякал))

Пересечение 2-ух отрезков
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
struct pt {
    int x, y;
};
 
inline int area (pt a, pt b, pt c) {
    return (b.x - a.x) * (c.y - a.y) - (b.y - a.y) * (c.x - a.x);
}
 
inline bool intersect_1 (int a, int b, int c, int d) {
    if (a > b)  swap (a, b);
    if (c > d)  swap (c, d);
    return max(a,c) <= min(b,d);
}
 
bool intersect (pt a, pt b, pt c, pt d) {
    return intersect_1 (a.x, b.x, c.x, d.x)
        && intersect_1 (a.y, b.y, c.y, d.y)
        && area(a,b,c) * area(a,b,d) <= 0
        && area(c,d,a) * area(c,d,b) <= 0;
}
Добавлено через 54 секунды
вот еще кое что

Главной здесь является функция , которая пересекает два переданных ей отрезка, и если они пересекаются хотя бы по одной точке, то возвращает , а в аргументах и возвращает начало и конец отрезка-ответа (в частности, когда ответ — это единственная точка, возвращаемые начало и конец будут совпадать).
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
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
const double EPS = 1E-9;
 
struct pt {
    double x, y;
 
    bool operator< (const pt & p) const {
        return x < p.x-EPS || abs(x-p.x) < EPS && y < p.y - EPS;
    }
};
 
struct line {
    double a, b, c;
 
    line() {}
    line (pt p, pt q) {
        a = p.y - q.y;
        b = q.x - p.x;
        c = - a * p.x - b * p.y;
        norm();
    }
 
    void norm() {
        double z = sqrt (a*a + b*b);
        if (abs(z) > EPS)
            a /= z,  b /= z,  c /= z;
    }
 
    double dist (pt p) const {
        return a * p.x + b * p.y + c;
    }
};
 
#define det(a,b,c,d)  (a*d-b*c)
 
inline bool betw (double l, double r, double x) {
    return min(l,r) <= x + EPS && x <= max(l,r) + EPS;
}
 
inline bool intersect_1d (double a, double b, double c, double d) {
    if (a > b)  swap (a, b);
    if (c > d)  swap (c, d);
    return max (a, c) <= min (b, d) + EPS;
}
 
bool intersect (pt a, pt b, pt c, pt d, pt & left, pt & right) {
    if (! intersect_1d (a.x, b.x, c.x, d.x) || ! intersect_1d (a.y, b.y, c.y, d.y))
        return false;
    line m (a, b);
    line n (c, d);
    double zn = det (m.a, m.b, n.a, n.b);
    if (abs (zn) < EPS) {
        if (abs (m.dist (c)) > EPS || abs (n.dist (a)) > EPS)
            return false;
        if (b < a)  swap (a, b);
        if (d < c)  swap (c, d);
        left = max (a, c);
        right = min (b, d);
        return true;
    }
    else {
        left.x = right.x = - det (m.c, m.b, n.c, n.b) / zn;
        left.y = right.y = - det (m.a, m.c, n.a, n.c) / zn;
        return betw (a.x, b.x, left.x)
            && betw (a.y, b.y, left.y)
            && betw (c.x, d.x, left.x)
            && betw (c.y, d.y, left.y);
    }
}
Добавлено через 18 минут
воообщем нужны еще функции деления отрезка на части, угол между 2-мя отрезками и параллельный перенос 2-ух отрезков.и как потом все это встроить в класс, который написал rangerx?
0
LK
26.02.2012, 19:18
  #6
 Комментарий модератора 
пацанчо, используйте тег вставки кода :
[CPP ]без пробелов[ /CPP] или кнопка С++ на панели окна редактирования сообщения
Если с вашей стороны и в дальнейшем будут куски не оформленного кода, можете рассчитывать на последнее китайское предупреждение, а ваша и так не очень гламурная репутация уйдет в глубокое небытие.
1
Модератор
3343 / 2120 / 347
Регистрация: 13.01.2012
Сообщений: 8,261
04.03.2012, 23:16 7
угол между двумя отрезками - это умножение векторов, перенос - сложение

класс с векторами

Добавлено через 1 минуту
ой.. вот он - Создать класс, для работы с динамическими векторами
1
Модератор
3343 / 2120 / 347
Регистрация: 13.01.2012
Сообщений: 8,261
18.03.2012, 16:07 8
что не то?
вы:
Цитата Сообщение от пацанчо Посмотреть сообщение
угол между 2-мя отрезками и параллельный перенос 2-ух отрезков
я:
Цитата Сообщение от vxg Посмотреть сообщение
угол между двумя отрезками - это умножение векторов, перенос - сложение
в архиве: описаны операции над векторами
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.03.2012, 16:07

Класс "Отрезок в двумерном пространстве"
Никак не могу сообразить, как же решается данная задачка. точнее, как будет вообще выглядеть...

Описать класс "Отрезок"
Написать программу для класса отрезки. Вот примерный код не могу придумать что то для отрезков....

Создать абстрактный класс "Издание" и производные классы "Книга", "Статья", "Электронный ресурс"
1. Создать абстрактный класс Издание с методами, позволяющими вывести на экран информацию об...

Создать класс "Вентилятор" содержащий в себе классы: "Двигатель", "Контроллер", "Пульт управления"
Помогите с кодом написания задачи, не понимаю как написать классы в классе. Нужно создать класс...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru