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

ООП (классы)

05.04.2021, 12:59. Показов 970. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Требование к заданию:
1) начальный класс, который будет служить родительским классом (суперклассом) во второй части задания (тема - классы и экземпляры)
2) дочерний класс, который наследуется от родительского класса из первой части задания (тема - наследование)
3) класс, содержащий экземпляры класса из второй части задания (тема - композиция).
Каждый класс должен содержать конструктор, метод__str__
Задания:
1)Создать класс, который представляет многочлен на основе списка коэффициентов. Отображение экземпляра класса подать на экран в формате "P_3 (x) = 4x ^3 - 2x + 3". Реализовать методы вычисления значения многочлена в точке. Перезагрузить перегрузить оператор "+" так, чтобы он суммировал многочлены.
2)Создать дочерний класс, который содержит информацию: порядок многочлена и его производную.
3)Создать класс, который содержит список многочленов (с возможностью добавления и удаления), реализовать метод отображения многочленов лишь определенного порядка.
Буду очень благодарен любой помощи.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.04.2021, 12:59
Ответы с готовыми решениями:

ООП классы со словарями
Есть задача: Реализовать через ООП базу данных о школе, используя классы и объекты: Класс Pupil - ученик поля: имя и оценки по...

ООП, классы и объекты. О-нтация
У вас есть Родительский класс Car: class Car(object): brand = 'Mazda' max_speed = 100 color = 'black' def...

Изучаю Python, сейчас учу основы ООП, где можно найти задачи по ООП
Скиньте пожалуйста источники с задачами(желательно на русском)

8
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
05.04.2021, 13:03
Outsiders, и в чем проблема?
0
0 / 0 / 0
Регистрация: 14.03.2021
Сообщений: 11
05.04.2021, 13:06  [ТС]
К сожалению, не знаю как это реализовать
0
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
05.04.2021, 13:08
Цитата Сообщение от Outsiders Посмотреть сообщение
К сожалению, не знаю как это реализовать
А ты пытался?
0
0 / 0 / 0
Регистрация: 14.03.2021
Сообщений: 11
05.04.2021, 13:10  [ТС]
Да, я бы не обращался за помощью просто так
0
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
05.04.2021, 13:11
Цитата Сообщение от Outsiders Посмотреть сообщение
Да, я бы не обращался за помощью просто так
Ну покажи попытки тогда.
0
102 / 85 / 25
Регистрация: 21.05.2019
Сообщений: 481
05.04.2021, 13:13
Это точно на python задание для новичков? Больше походит на С#
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
05.04.2021, 18:29
Цитата Сообщение от RSAX Посмотреть сообщение
Больше походит на С#
Почему?
0
0 / 0 / 0
Регистрация: 14.03.2021
Сообщений: 11
06.04.2021, 23:56  [ТС]
Что-то такое:
Python
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
from itertools import zip_longest
 
class Polynomial:
    def init(self, koeffs=[]):
        self.koeffs = koeffs
 
    def str(self):
        koeff = len(self.koeffs) - 1
        s = f'P_{koeff}(x) = '
        for k in self.koeffs:
            if k < 0:
                k = ' - ' + str(k)[-1:]
                if koeff == 1:
                    s += f'{k}x'
                elif koeff == 0:
                    s += f'{k}'
                elif k == ' - 1':
                    s += f' - {k}x^{koeff}'
                else:
                    s += f'{k}x^{koeff}'
            elif k == 0:
                pass
            else:
                if koeff == 1:
                    s += f' + {k}x'
                elif koeff == 0:
                    s += f' + {k}'
                elif k == 1:
                    s += f' + x^{koeff}'
                else:
                    if koeff == len(self.koeffs) - 1:
                        s += f'{k}x^{koeff}'
                    else:
                        s += f' + {k}x^{koeff}'
            koeff -= 1
        if s[s.index('=')+3] == '+':
            s = s[:s.index('=')+2] + s[s.index('=')+5:]
        return s
 
    def add(self, other):
        self.koeffs = [x + y for x, y in zip_longest(self.koeffs, other, fillvalue=0)]
        return self.str()
 
    def multi(self, point):
        koeff = len(self.koeffs) - 1
        res = 0
        for k in self.koeffs:
            if koeff > 1 or koeff < -1:
                res += k*(point**koeff)
            elif koeff == 1:
                res += k*point
            else:
                res += k
            koeff -= 1
        return res
 
 
class Derivative(Polynomial):
    def init(self, koeffs=[]):
        Polynomial.init(self, koeffs=[])
        self.info = len(self.koeffs)-1
        self.koeffs = koeffs
 
    def derivative(self):
        self.koeffs.pop()
        koeff = len(self.koeffs)
        s = f'P_{koeff}(x) = '
        for k in self.koeffs:
            print(k, koeff)
            if k < 0:
                if koeff == 2:
                    s += f'{k*koeff}x'
                elif koeff == 1:
                    s += f'{k}'
                elif k == ' - 1':
                    s += f' - {koeff}x^{koeff-1}'
                else:
                    s += f'{k*koeff}x^{koeff-1}'
            elif k == 0:
                pass
            else:
                if koeff == 2:
                    s += f' + {k*koeff}x'
                elif koeff == 1:
                    s += f' + {k}'
                elif k == 1:
                    s += f' + x^{koeff-1}'
                else:
                    s += f' + {k*koeff}x^{koeff-1}'
            koeff -= 1
        if s[s.index('=') + 3] == '+':
            s = s[:s.index('=') + 2] + s[s.index('=') + 5:]
        return s
 
 
poly = Polynomial([2, 0, -3, 4, 5])
print(poly.str())
print(poly.multi(2))
deri = Derivative([0, 3, -3, 3, 8])
print(deri.derivative())
Добавлено через 3 минуты
Это без третього задания. Может кто-то сможет улучшить этот код
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.04.2021, 23:56
Помогаю со студенческими работами здесь

Классы, задача, ооп
Создать класс Person. У экземпляров данного класса должно быть одно поле name, которое будет присваиваться пользователем при создании....

Проблема в понимании ООП(абстрактные классы, классы интерфейсы)
Всем здравия. Читал в свое время разные книги(к примеру, Гради Буч по проектированию) вроде все было понятно. Но тут с толкнулся с...

ООП Классы
#include &lt;iostream&gt; #include &lt;vector&gt; #include &lt;string&gt; #include &lt;iomanip&gt; #include &lt;sstream&gt; #include &lt;limits&gt; using...

ООП классы
Добрый день.Суть проблемы в том,что я не знаю как делать это задание.Так же нужно сделать диаграмму классов письменно,но с этим я разберусь...

КЛАССЫ ООП
Разработать классы с использованием контейнера, разработать методы ввода данных с клавиатуры в контейнер, сохранение элементов в файле,...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru