📣 独立日限时特惠: VIP通行证立减$68
12
返回列表 发新帖
楼主: outsider9798
跳转到指定楼层
上一主题 下一主题
收起左侧

求IXL Message ABC经典面经的具体题目内容

地里匿名用户
🔗
匿名用户-IUYRU  2023-3-18 11:38:27
本帖最后由 匿名 于 2023-3-17 20:39 编辑

紫薯紫薯紫薯紫薯
回复

使用道具 举报

🔗
happyworld23 2023-3-18 12:03:06 | 只看该作者
全局:
坂道的途中 发表于 2022-12-21 23:51
找到·原来发的答案,应该是work的:
第三题我是用stack做的,用三个stack去分别存A,B和C,如果发现stack ...

三个stack的话这个test case怎么过啊
a1 a2 a3 b b b c2 c1 c3
回复

使用道具 举报

全局:
def process_logs(logs):
    a_logs = set()
    b_indexes = []
    for i in range(len(logs)):
        log = logs[i]
        if log[0] == "A":
            client_id = log[1]
            a_logs.add(client_id)
        if log[0] == "B":
            b_indexes.append(i)
        if log[0] == "C":
            client_id = log[1]
            if client_id in a_logs:
                a_logs.remove(client_id)
                b_index = b_indexes.pop(0)
                logs[b_index] = "B" + str(client_id)

    return logs

直接这样不可以吗?更直接的方式
我们只在乎A的client id
只在乎C出现的时候的client id
中间包起来的第一个B自然会去update成最先被AC包起来的id
回复

使用道具 举报

全局:
微信用户_26dd9aa 发表于 2024-4-12 03:41
def process_logs(logs):
    a_logs = set()
    b_indexes = []

其他地方看到这个follow up:输入有可能missing A和B,比如 A1 B C2 C1 这种 ,C2对应的A2 B2丢了,但还是valid的然后填充B的id成A1 B1 C2 C1

这种情况怎么解决
回复

使用道具 举报

全局:
微信用户_26dd9aa 发表于 2024-4-12 03:41
def process_logs(logs):
    a_logs = set()
    b_indexes = []

['A1', 'B', 'A3', 'B', 'A2', 'C3', 'C1', 'B', 'C2'] 这种情况就不太对
回复

使用道具 举报

地里匿名用户
🔗
匿名用户-74ZA9  2024-5-1 10:40:07
sicheng2022 发表于 2023-2-7 18:32
为什么要用stack不能用queue 一直没想明白?

应为这题的greedy解法需要forward greedy,不能反向greedy
回复

使用道具 举报

地里匿名用户
🔗
匿名用户-74ZA9  2024-5-1 10:40:54
  1. testCase1 = "A2 B A1 B C2 C1"
  2. testCase2 = "A2 A1 B C2 B C1"

  3. // forward greedy solution, time: O(n)
  4. def decodeMessage(log: str) -> str:
  5.     # figure out the A that needs assign, and the location of B
  6.     a_map = {} # key: number, value: array of letter that we have encountered
  7.     b_arr = []
  8.     log_arr = log.split(" ")
  9.     for i in range(len(log_arr)):
  10.         l = log_arr[i]
  11.         # only B without number
  12.         if len(l) == 1:
  13.             # input to another array to be used later
  14.             b_arr.append(i)
  15.             
  16.         # letter with number
  17.         elif len(l) == 2:
  18.             c = l[0]
  19.             num = l[1]
  20.             
  21.             if c == 'A':
  22.                 if num not in a_map:
  23.                     a_map[num] = []
  24.                 a_map[num].append('A')
  25.             
  26.             if c == 'C':
  27.                 if len(a_map[num]) == 2:
  28.                     del a_map[num]
  29.             
  30.     print(a_map)
  31.             
  32.     for i in range(len(log_arr)):
  33.         l = log_arr[i]
  34.         if len(l) == 2:
  35.             c = l[0]
  36.             num = l[1]
  37.             if c == 'A' and num in a_map:
  38.                 log_arr[b_arr[0]] += num
  39.                 print(log_arr[b_arr[0]])
  40.                 b_arr.pop(0)
  41.    
  42.     ret = " ".join(log_arr)
  43.     return ret

  44. ret = decodeMessage(testCase1)
  45. print(ret)
  46. ret = decodeMessage(testCase2)
  47. print(ret)
复制代码
回复

使用道具 举报

地里匿名用户
🔗
匿名用户-IMYVL  2026-1-16 12:28:24
坂道的途中 发表于 2022-12-22 06:51
找到·原来发的答案,应该是work的:
第三题我是用stack做的,用三个stack去分别存A,B和C,如果发现stack ...

谢谢啦,思路牛逼

另外用queue其实也可以,而且更符合直觉。谢谢贡献思路。 加米了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表