- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我为我本地的写作小组制作了一个简单的应用程序,该应用程序“随机”将小组分成两半,以确定他们是在橙色房间还是蓝色房间。我的方法有效,人数从不超过 20 人,但我知道这是一种蛮力方法,不适用于非常大的人数。
我试图为这种方法留下好的评论,但如果有任何混淆,我会很乐意更新问题。
// Splits people into three groups, anchors, people with pages, and people without pages. Then it evenly(as possible) distributes people with and without pages into two groups.
public ArrayList<Person> shuffle() {
ArrayList<Person> haveNoPages = new ArrayList<>(); // people who don't have pages, including anchors.
ArrayList<Person> anchorList = new ArrayList<>(); // people who are Anchors.
// Split people who don't have pages
for(int i = 0; i < people.size(); i++){
if(people.get(i).getPages().equals("0")){
haveNoPages.add(people.get(i));
people.remove(i);
i--;
}
}
// holds the anchors temporarily
for (int i = 0; i < people.size(); i++) {
if (people.get(i).isBlueA() || people.get(i).isOrangeA()) {
anchorList.add(people.get(i));
people.remove(i);
i--;
}
}
// Randomize the lists to "draw" names.
Collections.shuffle(people);
Collections.shuffle(haveNoPages);
// Alternate group placement until the list is empty.
for (int i = 0; i < people.size(); i++) {
if (i % 2 == 0) {
people.get(i).setGroup("Orange");
} else {
people.get(i).setGroup("Blue");
}
}
// Alternate group placement until the list is empty.
for (int i = 0; i < haveNoPages.size(); i++) {
if (i % 2 == 0) {
haveNoPages.get(i).setGroup("Orange");
} else {
haveNoPages.get(i).setGroup("Blue");
}
}
// Recombine the list and return it.
people.addAll(anchorList);
people.addAll(haveNoPages);
anchorList.clear();
haveNoPages.clear();
return people;
}
我最初的想法是将所有内容组合到一个 for 循环中,然后使用 boolean 值在每种类型的人之间交替显示蓝色和橙色组。示例:
for (int i = 0; i < people.size(); i++) {
if (i % 2 == 0 && !people.get(i).isBlueA() && !people.get(i).isOrangeA()) {
people.get(i).setGroup("Orange");
} else if (!people.get(i).isBlueA() && !people.get(i).isOrangeA()) {
people.get(i).setGroup("Blue");
}
}
此解决方案的问题是我不知道如何确保没有页面的人被集中在一个无用的组中。我需要每个“类型”均匀分布。
排序不当的组示例:
蓝色组
橙色集团
Alex - 5 页
玛丽莎 - 6 页
John(主播)- 2 页
希望这可以清楚地说明我为什么要对组进行排序并将组分别分配给每个子集。我需要确保每个组中有页面的人数是偶数,这样一组人就不会胡思乱想了。
我最终想更进一步,找出一种方法来考虑每个人带来的页数,但这是以后要担心的事情。
最佳答案
前几天我也在想类似的事情。关于如何使用带有计数器的“ transient ”列表。
基本上,使用 3 个独立的计数器来保持 {Anchor, >0, =0} 的连续计数。当您遍历人员列表时,确定类型,使用模数检查计数器以确定蓝色或橙色,然后递增。
// Evenly(as possible) distributes people with and without pages into two groups.
public ArrayList<Person> shuffle() {
int anAnchorCount = 0; // useless?
int hasPagesCount = 0;
int emptyHanded = 0;
// Split people who don't have pages
for(Person p : people){
if (p.isBlueA() || p.isOrangeA()){
// skip ?? ... Already assigned?
anAnchorCount++;
}
else if(p.getPages().equals("0")){
p.setGroup((emptyHanded++ % 2 == 0) ? "Orange" : "Blue");
}
else
p.setGroup((hasPagesCount++ % 2 == 0) ? "Orange" : "Blue");
}
return people;
}
如果可行,那么它就是 O(N)。
稍后,您可以使用桶根据页数平均分配。您的 if/elseif/else
树只会检查范围。
关于java - 有没有更有效的方法来随机化然后将 3 个数据子集均匀分布组合?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44119271/
我想了解 Ruby 方法 methods() 是如何工作的。 我尝试使用“ruby 方法”在 Google 上搜索,但这不是我需要的。 我也看过 ruby-doc.org,但我没有找到这种方法。
Test 方法 对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。 object.Test(string) 参数 object 必选项。总是一个
Replace 方法 替换在正则表达式查找中找到的文本。 object.Replace(string1, string2) 参数 object 必选项。总是一个 RegExp 对象的名称。
Raise 方法 生成运行时错误 object.Raise(number, source, description, helpfile, helpcontext) 参数 object 应为
Execute 方法 对指定的字符串执行正则表达式搜索。 object.Execute(string) 参数 object 必选项。总是一个 RegExp 对象的名称。 string
Clear 方法 清除 Err 对象的所有属性设置。 object.Clear object 应为 Err 对象的名称。 说明 在错误处理后,使用 Clear 显式地清除 Err 对象。此
CopyFile 方法 将一个或多个文件从某位置复制到另一位置。 object.CopyFile source, destination[, overwrite] 参数 object 必选
Copy 方法 将指定的文件或文件夹从某位置复制到另一位置。 object.Copy destination[, overwrite] 参数 object 必选项。应为 File 或 F
Close 方法 关闭打开的 TextStream 文件。 object.Close object 应为 TextStream 对象的名称。 说明 下面例子举例说明如何使用 Close 方
BuildPath 方法 向现有路径后添加名称。 object.BuildPath(path, name) 参数 object 必选项。应为 FileSystemObject 对象的名称
GetFolder 方法 返回与指定的路径中某文件夹相应的 Folder 对象。 object.GetFolder(folderspec) 参数 object 必选项。应为 FileSy
GetFileName 方法 返回指定路径(不是指定驱动器路径部分)的最后一个文件或文件夹。 object.GetFileName(pathspec) 参数 object 必选项。应为
GetFile 方法 返回与指定路径中某文件相应的 File 对象。 object.GetFile(filespec) 参数 object 必选项。应为 FileSystemObject
GetExtensionName 方法 返回字符串,该字符串包含路径最后一个组成部分的扩展名。 object.GetExtensionName(path) 参数 object 必选项。应
GetDriveName 方法 返回包含指定路径中驱动器名的字符串。 object.GetDriveName(path) 参数 object 必选项。应为 FileSystemObjec
GetDrive 方法 返回与指定的路径中驱动器相对应的 Drive 对象。 object.GetDrive drivespec 参数 object 必选项。应为 FileSystemO
GetBaseName 方法 返回字符串,其中包含文件的基本名 (不带扩展名), 或者提供的路径说明中的文件夹。 object.GetBaseName(path) 参数 object 必
GetAbsolutePathName 方法 从提供的指定路径中返回完整且含义明确的路径。 object.GetAbsolutePathName(pathspec) 参数 object
FolderExists 方法 如果指定的文件夹存在,则返回 True;否则返回 False。 object.FolderExists(folderspec) 参数 object 必选项
FileExists 方法 如果指定的文件存在返回 True;否则返回 False。 object.FileExists(filespec) 参数 object 必选项。应为 FileS
我是一名优秀的程序员,十分优秀!