合租分房策略

原因

假设是一个三居室小区房,因为房型的原因,三个卧室在每个人心里,必定是有上中下之分的。

目标

  • 每个人都能以心中理想的价格拿到自己的房间。

解决策略

e.g 月租金5500元,每个人在互不知情的情况下,针对三个卧室分别给出一个心中的理想价格(以10元为单位),并保证给出的价格总和为5500。如下表:

卧室1卧室2卧室3总和
小王x1y1z1x1+y1+z1=5500
小张x2y2z2x2+y2+z2=5500
小李x3y3z3x3+y3+z3=5500
  1. 首先取9个数中最大的那个数,不妨设为x3(x3>=x1且x3>=x2)。此时小李以x3的价格中标“卧室1”。

  2. 再在y1、z1、y2、z2四个数中,选择最大的那个数,不妨设为y1(y1>=y2)。此时小王以y1的价格中标“卧室2”。

  3. 小张自动以z2的价格中标“卧室3”。

  4. 此时,x3+y1+z2 >= x2 + y2 + z2 = 5500,多余的钱充当公共的物业费。

补充

选择最大的数,若两个数相同,可以采用以下策略:

  • 法1 避免 : 细化竞价时的粒度,比如设为以5元为单位
  • 法2 解决 : 一次猜拳
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是一个简单的房屋租赁管理系统的类设计和示例程序: ```python class Room: def __init__(self, room_id, rent, rented, renter=None): self.room_id = room_id # 房间编号 self.rent = rent # 单价 self.rented = rented # 已租时间 self.renter = renter # 租客对象 def is_empty(self): return self.renter is None def rent_out(self, renter): self.renter = renter def rent_end(self): self.rented = 0 self.renter = None class Renter: def __init__(self, name, start_month): self.name = name # 租客名字 self.start_month = start_month # 租赁开始月份 def __str__(self): return "Renter: %s, start_month: %d" % (self.name, self.start_month) class RentingManager: def __init__(self, rooms): self.rooms = rooms # 所有房间列表 def rent_room(self, room_id, renter): for room in self.rooms: if room.room_id == room_id and room.is_empty(): room.rent_out(renter) return True return False def end_rent(self, room_id): for room in self.rooms: if room.room_id == room_id and not room.is_empty(): room.rent_end() return True return False def list_all_rooms(self): print("RoomID\tRent\tRented\tRenterName") for room in self.rooms: rented = "3 months" if room.rented < 3 else "%d months" % room.rented renter_name = room.renter.name if not room.is_empty() else "" print("%s\t%s\t%s\t%s" % (room.room_id, room.rent, rented, renter_name)) ``` 接下来是一个简单的示例程序,模拟租赁和退房操作: ```python # 初始化房间列表 rooms = [ Room("A101", 1000, 0), Room("A102", 1200, 0), Room("A103", 1500, 2, Renter("Jack", 2)), ] manager = RentingManager(rooms) # 列出所有房间 manager.list_all_rooms() # 租客租赁房间A101 renter = Renter("Tom", 3) if not manager.rent_room("A101", renter): print("Room A101 is not available") else: print("Rent room A101 to %s" % renter.name) # 再次列出所有房间 manager.list_all_rooms() # Jack退租房间A103 if not manager.end_rent("A103"): print("Cannot end rent for room A103") else: print("Renter Jack has ended rent for room A103") # 再次列出所有房间 manager.list_all_rooms() ``` 该程序的输出结果为: ``` RoomID Rent Rented RenterName A101 1000 0 A102 1200 0 A103 1500 2 Jack Rent room A101 to Tom RoomID Rent Rented RenterName A101 1000 3 months Tom A102 1200 0 A103 1500 2 Jack Renter Jack has ended rent for room A103 RoomID Rent Rented RenterName A101 1000 3 months Tom A102 1200 0 A103 1500 0 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值