V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
eastphoton
V2EX  ›  LeetCode

一直很好奇 leetcode 是怎么判断随机算法的正误的

  •  
  •   eastphoton · 2022-06-26 13:45:17 +08:00 · 3095 次点击
    这是一个创建于 883 天前的主题,其中的信息可能已经有所发展或是发生改变。

    比如今天的每日一题: https://leetcode.cn/problems/random-pick-with-blacklist/, 还有这些: https://leetcode.cn/tag/randomized/problemset/

    毕竟随机结果没法直接对比标准答案,感觉要判断正误就挺麻烦,但 leetcode 可以测出来正确性。

    有时候写出来某个细节差个+1 -1 ,那概率分布也差不太多吧,它也能测出来有错误不给 AC 。 感觉就挺神奇的。

    没有搜到有对这个的讨论。。

    6 条回复    2022-06-26 20:16:43 +08:00
    stein42
        1
    stein42  
       2022-06-26 14:59:42 +08:00   ❤️ 1
    应该是用统计学里的假设检验来验证,这里是离散均匀分布,可以用皮尔森卡方检定。
    假设检验本身就可能犯第一类错误(拒绝正确结果)和第二类错误(接受错误结果)。
    我试过,轻微改变分布还是能通过。

    ```
    import bisect
    import random


    class Solution:
    ....def __init__(self, n: int, blacklist: List[int]):
    ........self.m = n - len(blacklist)
    ........self.ss = [a - i for i, a in enumerate(sorted(blacklist))]

    ....def pick(self) -> int:
    ........r = random.randrange(self.m)
    ........return r + bisect.bisect_right(self.ss, r)
    ```

    ```
    import bisect
    import random


    class Solution:
    ....def __init__(self, n: int, blacklist: List[int]):
    ........self.m = n - len(blacklist)
    ........self.ss = [a - i for i, a in enumerate(sorted(blacklist))]

    ....def pick(self) -> int:
    ........if random.random() < 1 / (100 * self.m):
    ............r = 0
    ........else:
    ............r = random.randrange(self.m)
    ........return r + bisect.bisect_right(self.ss, r)
    ```
    virusdefender
        2
    virusdefender  
       2022-06-26 18:15:27 +08:00
    special judge 吧,也就是写一段代码来判断,各种 oj 都有这功能
    SingeeKing
        3
    SingeeKing  
       2022-06-26 19:13:32 +08:00 via iPhone
    咱就说,有没有一种可能,他是跑了你的代码然后检查输入输出
    SingeeKing
        4
    SingeeKing  
       2022-06-26 19:14:28 +08:00 via iPhone
    哦不我看错了,忽略我…
    adjusted
        5
    adjusted  
       2022-06-26 20:14:31 +08:00   ❤️ 1
    random 设置下 seed 吧
    wy315700
        6
    wy315700  
       2022-06-26 20:16:43 +08:00 via Android
    special judge 写一段代码来检测你的输出的,写 oj 的时候经常用到的,除了随机数算法,一些涉及浮点数的可能也要用到
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3367 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 12:35 · PVG 20:35 · LAX 04:35 · JFK 07:35
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.