Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 13.06.2015
Сообщений: 23

Сравнить два объекта

29.05.2018, 02:12. Показов 963. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Собственно задача:
Класс должен содержать следующие свойства:
- координаты вершин четырёхугольника;
- величины углов четырёхугольника;
- периметр четырёхугольника.

Класс должен содержать следующие методы:
- геттеры и сеттеры для координат;
- геттеры для величин углов;
- геттер для периметра;
- метод, вычисляющий величины всех углов четырёхугольника в градусах (результаты заносятся в соответствующие свойства класса);
- метод, вычисляющий периметр четырёхугольника (результаты заносятся в соответствующее свойство класса);
- метод, сравнивающий два четырёхугольника по величине периметра (в качестве параметра принимается объект класса "Четырёхугольник").

Мой код
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
#include "stdafx.h"
#include <iostream>
 
class figure {
private:
    double x[4], y[4], ug[4], p;
public:
    void set_coord(double x_cord, double y_cord, int i_cord) // сеттер координат
    {
        x[i_cord] = x_cord;
        y[i_cord] = y_cord;
    }
    double get_angle(int i) // геттер углов
    {
        ug[0] = angle(x[0], y[0], x[1], y[1], x[3], y[3]);
        ug[1] = angle(x[1], y[1], x[0], y[0], x[2], y[2]);
        ug[2] = angle(x[2], y[2], x[1], y[1], x[3], y[3]);
        ug[3] = angle(x[3], y[3], x[2], y[2], x[0], y[0]);
        return ug[i];
    }
    double angle(double x0, double y0, double x1, double y1, double x2, double y2) // метод вычисляющий углы
    {
        double angle;
        angle = (acos(double(((x1 - x0)*(x2 - x0) + (y1 - y0)*(y2 - y0)) / (sqrt((x1 - x0)*(x1 - x0) + (y1 - y0)*(y1 - y0))*sqrt((x2 - x0)*(x2 - x0) + (y2 - y0)*(y2 - y0)))))) * 180 / 3.14;
        return angle;
 
    }
    double get_perimeter() // метод для расчета периметра
    {
        p = ((sqrt((x[1] - x[0])*(x[1] - x[0]) + (y[1] - y[0])*(y[1] - y[0])) + sqrt((x[3] - x[0])*(x[3] - x[0]) + (y[3] - y[0])*(y[3] - y[0])) + (sqrt((x[2] - x[1])*(x[2] - x[1]) + (y[2] - y[1])*(y[2] - y[1])) + sqrt((x[2] - x[3])*(x[2] - x[3]) + (y[2] - y[3])*(y[2] - y[3])))));
        return p;
    }
    /*void result(figure p0, figure p1) // метод сравнения
    {
        if (p0 > p1) std::cout << "\nРезультат: Периметр первого четырехугольника больше, чем второго.\n" << std::endl;
        else std::cout << "\nРезультат: Периметр второго четырехугольника больше, чем периметр первого.\n" << std::endl;
    }*/
};
 
 
int main()
{
    setlocale(LC_ALL, "Russian");
    figure obj;
    double x, y;
    for (int j = 0; j < 2; j++)
    {
        std::cout << "\t\tФигура #" << j+1 << "\n";
        std::cout << "Вводите координаты точек по порядку их расположения: " << std::endl;
        for (int i = 0; i < 4; i++)
        {
            std::cout << "X[" << i << "]: ";
            std::cin >> x;
            std::cout << "Y[" << i << "]: ";
            std::cin >> y;
            obj.set_coord(x, y, i);
        }
        for (int i = 0; i < 4; i++)
        {
            std::cout << "Угол точки " << i << ": " << obj.get_angle(i) << std::endl;
        }
        std::cout << "Периметр: " << obj.get_perimeter() << std::endl;
    }
    return 0;
}
Всячески пробовал, никак не получается сравнить периметры четырехугольников, используя в качестве параметра объект.
Т.е меня интересует именно то, как сравнивать объекты? в качестве параметра метода
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.05.2018, 02:12
Ответы с готовыми решениями:

Сравнить два массива
Подскажите пожалуйста как решить задачу: Нужно сравнить два массива, проверить все элементы на совпадение и если они совпадают то вывести...

Сравнить два массива
Всем привет, помогите найти ошибку, я уже не знаю в чем дело, пытаюсь сравнить два массива, выводит 3 совпадения из 4 #include...

Сравнить два массива
Доброго дня ! Как-то с полгода назад мне понадобилась программа (с комбинаторикой), сравнивающая два массива - masС cравнить с masD. ...

1
322 / 174 / 78
Регистрация: 09.10.2014
Сообщений: 809
29.05.2018, 07:27
C++
1
2
3
4
bool operator<(const figure& other)
{
    return get_perimeter() < other.get_perimeter();
}
Добавлено через 5 минут
И p пометить как mutable. Или пересмотреть стратегию высчитывания периметра. А то зачем хешировать, если каждый раз пересчитываем.

Или флаг поставить, чтоб периметр вычислялся 1 раз а потом просто выдавал. Флаг сбрасывать при изменении точек.
Или вычислять p при изменении точек.
Или вообще убрать p из класса.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.05.2018, 07:27
Помогаю со студенческими работами здесь

Сравнить два поля узла
Имеется двусвязный список фишек домино. В нём два поля: левое и правое числа фишки домино. Нужно пробежать такой цикл, чтобы выяснить...

Сравнить логически два массива
Сравнить , используя логическое или(||) два одномерных массива (А и В) и записать результат в массив С Массивы создал , но не знаю как...

Сравнить два вектора размерности n
Как сравнить два вектора размерности n? Например вектор a(2,3,2) сравнить с вектором b(1,3,3). Какой из векторов больше? Вообще можно ли их...

Сравнить два вектора по длине
Заданы два вектора a ={ a 1 , a 2 , …, a n } и b ={ b 1 , b 2 , …, b n }. Определить тот из них, который имеет наименьшую длину.

Сравнить два введённых слова
Всем привет!! Помогите решить задачку: ввести два слова и сравнить их. Вот я почти решил, надо как-то внедрить проверку длины слова...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru