我想在 C 中创建一个函数。它将返回 N 范围内的随机整数,例如:-
兰特()%N;
但问题是我想追踪独特性。我不想让这些数字重复。但我也可以通过创建一个数组并在其中复制生成的整数来做到这一点。喜欢 :-array[count] = rand() % N;
并每次检查生成的数字是否已经在其中。 (只需在数组[]内搜索即可);这是一种简单但正确的方法。这需要很多如果和for;为了这个工作。
这是我能想到的最好的办法。
问题是,我想为这个问题找到最好的/优化的解决方案。最有效的方法是什么?
让我们澄清一些事情:-
我想在 NSArray 的 UILabel 中设置一些文本,该文本始终是唯一的。我的 NSArray 正在从 Plist 获取数据,并且我的 Plist 有超过 1000 个条目。如果我想多次执行此操作,则会影响性能,因此我需要一些有效的方法来执行此操作。
听起来你想要的实际上是数字 1..N 的随机排列。因此,用连续整数 1..N 填充数组,然后对数组进行打乱。有众所周知的洗牌算法你可以查一下。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)