Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

solution #1748

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 33 additions & 4 deletions app/main.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,37 @@
class Car:
# write your code here
pass
def __init__(self, comfort_class: int, clean_mark: int, brand: str) -> \

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There's a syntax error here due to the misplaced backslash. The backslash should be removed to correctly define the __init__ method.

None:
self.comfort_class = comfort_class
self.clean_mark = clean_mark
self.brand = brand


class CarWashStation:
# write your code here
pass
def __init__(self, distance_from_city_center: int, clean_power: int,
average_rating: int, count_of_ratings: int) -> None:
self.distance_from_city_center = distance_from_city_center
self.clean_power = clean_power
self.average_rating = average_rating
self.count_of_ratings = count_of_ratings

def calculate_washing_price(self, car: Car) -> None:
return round((car.comfort_class * (self.clean_power - car.clean_mark)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The expression car.comfort_class * (self.clean_power - car.clean_mark) is incorrect because comfort_class and clean_mark are expected to be integers, not strings. Ensure that the Car class is instantiated with integer values for these attributes.

* self.average_rating)
/ self.distance_from_city_center, 1)

def wash_single_car(self, car: Car) -> None:
if car.clean_mark < self.clean_power:
car.clean_mark = self.clean_power

def serve_cars(self, cars: Car) -> None:

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The serve_cars method should accept a list of Car objects, not a single Car object. Change the parameter type to List[Car] and ensure you import List from typing.

income = 0
for car in cars:
if car.clean_mark < self.clean_power:
income += self.calculate_washing_price(car)
self.wash_single_car(car)
return round(income, 1)

def rate_service(self, rating: int) -> None:
total_rating = (self.average_rating * self.count_of_ratings) + rating
self.count_of_ratings += 1
self.average_rating = round(total_rating / self.count_of_ratings, 1)
Loading