[["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 人都抽出来不就行了
|