
[["id1","1 班","男 101"],["id2","1 班","男 102"],["id3","3 班","男 101"],["id4","4 班","男 101"],["id5","1 班","女 101"],["id6","1 班","女 103"],["id7","6 班","女 101"],["id8","7 班","女 101"]]
1 macrorules 2022-04-04 13:23:22 +08:00 这个是数学问题吧,数学上怎么解啊? |
2 uni 2022-04-04 13:38:37 +08:00 一天抽几个人? |
3 dlsflh 2022-04-04 13:40:30 +08:00 你随便 random 生成抽检单,然后判断是否符合条件,不符合丢弃继续 random 。 |
4 MrSnake OP @macrorules 这个我也一直在尝试,但是会出现一天堆积的太多的情况 |
7 s4nd 2022-04-04 16:04:53 +08:00 按宿舍床位号来就行了,这种情况随机没啥用,随机还有可能连续随机到同一个 |
8 yankebupt 2022-04-04 16:15:50 +08:00 先抽班,再抽宿舍的同时合并 /复用同类项,人数不够随机补齐不行么。 看起来人不太多而且也不需要特别科学的抽法的样子…… |
11 SenLief 2022-04-04 17:16:27 +08:00 “每天每个宿舍和每个班级都要有人被抽检” 这个好像没给出一共有多少个宿舍。以及每天的抽检人和宿舍、班级是否可以重复。 |
12 wuxkwnjjwoxk 2022-04-04 18:36:51 +08:00 via iPhone 分层随机化 stratified sampling 很基础的东西,应该不难搜到教程 |
13 yaphets666 2022-04-05 02:27:26 +08:00 via iPhone 不想动脑的方法就是,首先所有的班一个 list ,所有的宿舍一个 list ,宿舍比班多,所以先按班抽,每个班抽一个出来。这样子就满足了第一个条件。然后除了第一步被抽中的人得宿舍,其他宿舍每个宿舍抽一个,这样就都满足了。 |
14 yaphets666 2022-04-05 02:30:00 +08:00 via iPhone 在提高一下条件,尽量抽没被抽中过的人,也不想动脑,那就是每个人加一个 count ,抽到就 count++,在抽每一步之前,所有班和宿舍内部按 count 排序 |
15 BeautifulSoap 2022-04-07 01:30:23 +08:00 via Android 这还不简单,没说抽几个人的话,10 个班比如总共 500 人,每天把这 500 人都抽出来不就行了 |