describe

Design a parking system for a parking lot. The parking lot has three kinds of parking spaces: big, medium, and small, with a fixed number of slots for each size.

Implement the ParkingSystem class:

ParkingSystem(int big, int medium, int small) Initializes object of the ParkingSystem class. The number of slots for each parking space are given as part of the constructor.
bool addCar(int carType) Checks whether there is a parking space of carType for the car that wants to get into the parking lot. carType can be of three kinds: big, medium, or small, which are represented by 1, 2, and 3 respectively. A car can only park in a parking space of its carType. If there is no space available, return false, else park the car in that size space and return true.
Copy the code

Example 1:

Input
["ParkingSystem", "addCar", "addCar", "addCar", "addCar"]
[[1, 1, 0], [1], [2], [3], [1]]
Output
[null, true, true, false, false]

Explanation
ParkingSystem parkingSystem = new ParkingSystem(1, 1, 0);
parkingSystem.addCar(1); // return true because there is 1 available slot for a big car
parkingSystem.addCar(2); // return true because there is 1 available slot for a medium car
parkingSystem.addCar(3); // return false because there is no available slot for a small car
parkingSystem.addCar(1); // return false because there is no available slot for a big car. It is already occupied.	
Copy the code

Note:

0 <= big, medium, small <= 1000
carType is 1, 2, or 3
At most 1000 calls will be made to addCar
Copy the code

parsing

As long as there are three kinds of parking Spaces in the parking lot each time, each of which has a corresponding number, each parking space only needs to judge whether the corresponding type of parking space is available. If there are three kinds of parking Spaces, return True; if there are not, return False. So long questions labeled “EASY” are paper brains!

answer

class ParkingSystem(object):
    def __init__(self, big, medium, small):
        """
        :type big: int
        :type medium: int
        :type small: int
        """
        self.big = big
        self.medium = medium
        self.small = small
        self.res = []

    def addCar(self, carType):
        """
        :type carType: int
        :rtype: bool
        """
        if carType==1:
            if self.big>0:
                self.big -= 1
                return True
            else:
                return False
        elif carType==2:
            if self.medium>0:
                self.medium -= 1
                return True
            else:
                return False
        elif carType==3:
            if self.small>0:
                self.small -= 1
                return True
            else:
                return False
        	      
		
Copy the code

The results

Given in the linked list. Memory Usage: 136 ms, faster than 31.05% for the linked list. 13 MB, less than 37.44% of Python online submissions for Design Parking System.Copy the code

Original link: leetcode.com/problems/de…

Your support is my biggest motivation