Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.81
пацанчо
-6 / 0 / 0
Регистрация: 02.04.2011
Сообщений: 38
#1

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

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

создать класс отрезок,чтобы также можно было вычислить длину отрезка
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.02.2012, 13:52
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Класс "Отрезок". Вычислить длину отрезка. (C++):

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

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

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

Описать класс "Отрезок" - C++
Написать программу для класса отрезки. Вот примерный код не могу придумать что то для отрезков. #include <string> #include <conio.h> ...

Создать класс "Книга" с полями "название книги", "количество страниц", "год издания" - C++
Создать класс Книга поля: название книги,количество страниц,год издания методы: вычислить сколько лет книге и количество дней прошедших...

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

7
Doctor Nano
Cандальная шляпа
42 / 42 / 10
Регистрация: 12.01.2012
Сообщений: 185
12.02.2012, 14:02 #2
А поточнее, можно?
0
rangerx
1935 / 1544 / 141
Регистрация: 31.05.2009
Сообщений: 2,913
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
__bool
285 / 226 / 6
Регистрация: 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
vxg
Модератор
3184 / 1987 / 227
Регистрация: 13.01.2012
Сообщений: 7,675
04.03.2012, 23:16 #7
угол между двумя отрезками - это умножение векторов, перенос - сложение

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

Добавлено через 1 минуту
ой.. вот он - Создать класс, для работы с динамическими векторами
1
vxg
Модератор
3184 / 1987 / 227
Регистрация: 13.01.2012
Сообщений: 7,675
18.03.2012, 16:07 #8
что не то?
вы:
Цитата Сообщение от пацанчо Посмотреть сообщение
угол между 2-мя отрезками и параллельный перенос 2-ух отрезков
я:
Цитата Сообщение от vxg Посмотреть сообщение
угол между двумя отрезками - это умножение векторов, перенос - сложение
в архиве: описаны операции над векторами
0
18.03.2012, 16:07
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.03.2012, 16:07
Привет! Вот еще темы с ответами:

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

Класс "Отрезок" - C++
Создать класс &quot;Отрезок&quot;. Создать и проинициализировать массив переменных данного класса. Вывести отрезки на экран. Вывести на экран...

Реализовать класс родительский класс "Пара чисел" и класс-наследник "Комплексное число" - C++
Ткма работы создать класс pair (пара чисел); определить метод перемножения полей и операцию сложения пар (a,b)+(c,d) =(a+b,c+d)...

Объект Отрезок. Создать методы вычисляющие длину отрезка и угол с осью X - C++
Дано відрізок: метод обчислення довжини, кута з віссю ОХ та їх виведення. Перевожу за ТС: Дан отрезок. Создать методы вычисления...


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

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

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