‘壹’ php中有没有办法可以随机打乱数组
当然可以,php是最好的语言!可以自己封装打乱的算法,也可以使用官方提供的函数shuffle就可以打乱数组信息了,具体用法可以参考官方手册,讲得非常详细,希望能帮到你。
‘贰’ PHP怎么随机获取数组里面的值
需要准备的材料分别是:电脑、php编辑器、浏览器。
1、首先,打开php编辑器,新建php文件,例如:index.php,并定义一个数组。
‘叁’ PHP产生不重复随机数的5个方法总结
无论是Web应用,还是WAP或者移动应用,随机数都有其用武之地。在最近接触的几个小项目中,我也经常需要和随机数或者随机数组打交道,所以,对于PHP如何产生不重复随机数常用的几种方法小结一下(ps:方法1、4、5是我常用的,其余来自网络整理)
方法一:
复制代码
代码如下:
<?php
$numbers
=
range
(1,50);
//shuffle
将数组顺序随即打乱
shuffle
($numbers);
//array_slice
取该数组中的某一段
$num=6;
$result
=
array_slice($numbers,0,$num);
print_r($result);
?>
方法二:
复制代码
代码如下:
<?php
$numbers
=
range
(1,20);
//播下随机数发生器种子,可有可无,测试后对结果没有影响
srand
((float)microtime()*1000000);
shuffle
($numbers);
//跳过list第一个值(保存的是索引)
while
(list(,
$number)
=
each
($numbers))
{
echo
"$number
";
}
?>
方法三:
复制代码
代码如下:
<?php
function
NoRand($begin=0,$end=20,$limit=5){
$rand_array=range($begin,$end);
shuffle($rand_array);//调用现成的数组随机排列函数
return
array_slice($rand_array,0,$limit);//截取前$limit个
}
print_r(NoRand());
?>
上述可以在1-20间随机产生5个不重复的值
方法四:
复制代码
代码如下:
<?php
$tmp=array();
while(count($tmp)<5){
$tmp[]=mt_rand(1,20);
$tmp=array_unique($tmp);
}
print_r($tmp);
?>
方法五:
复制代码
代码如下:
<?php
$tmp
=
range(1,30);
print_r(array_rand($tmp,10));
?>
这个可能是比叫简单的了(ps:如果在range中指定了步长,就必须注意array_rand的第二个参数是否超出$tmp的长度)。
PHP提供非常丰富的数组函数,产生随机数大多可以从数组这个角度出发,若你还有方法提供,欢迎给出,文章将持续更新。
‘肆’ 在php中怎么排序键值数组
array_change_key_case -- 返回字符串键名全为小写或大写的数组
array_chunk -- 将一个数组分割成多个
array_combine -- 创建一个数组,用一个数组的值作为其键名,另一个数组的值作为其值
array_count_values -- 统计数组中所有的值出现的次数
array_diff_assoc -- 带索引检查计算数组的差集
array_diff_uassoc -- Computes the difference of arrays with additional index check which is performed by a user supplied callback function.
array_diff -- 计算数组的差集
array_fill -- 用给定的值填充数组
array_filter -- 用回调函数过滤数组中的单元
array_flip -- 交换数组中的键和值
array_intersect_assoc -- 带索引检查计算数组的交集
array_intersect -- 计算数组的交集
array_key_exists -- 检查给定的键名或索引是否存在于数组中
array_keys -- 返回数组中所有的键名
array_map -- 将回调函数作用到给定数组的单元上
array_merge_recursive -- 递归地合并两个或多个数组
array_merge -- 合并两个或多个数组
array_multisort -- 对多个数组或多维数组进行排序
array_pad -- 用值将数组填补到指定长度
array_pop -- 将数组最后一个单元弹出(出栈)
array_push -- 将一个或多个单元压入数组的末尾(入栈)
array_rand -- 从数组中随机取出一个或多个单元
array_rece -- 用回调函数迭代地将数组简化为单一的值
array_reverse -- 返回一个单元顺序相反的数组
array_search -- 在数组中搜索给定的值,如果成功则返回相应的键名
array_shift -- 将数组开头的单元移出数组
array_slice -- 从数组中取出一段
array_splice -- 把数组中的一部分去掉并用其它值取代
array_sum -- 计算数组中所有值的和
array_udiff_assoc -- Computes the difference of arrays with additional index check. The data is compared by using a callback function.
array_udiff_uassoc -- Computes the difference of arrays with additional index check. The data is compared by using a callback function. The index check is done by a callback function also
array_udiff -- Computes the difference of arrays by using a callback function for data comparison.
array_unique -- 移除数组中重复的值
array_unshift -- 在数组开头插入一个或多个单元
array_values -- 返回数组中所有的值
array_walk -- 对数组中的每个成员应用用户函数
array -- 新建一个数组
arsort -- 对数组进行逆向排序并保持索引关系
asort -- 对数组进行排序并保持索引关系
compact -- 建立一个数组,包括变量名和它们的值
count -- 统计变量中的单元数目
current -- 返回数组中的当前单元
each -- 返回数组中当前的键/值对并将数组指针向前移动一步
end -- 将数组的内部指针指向最后一个单元
extract -- 从数组中将变量导入到当前的符号表
in_array -- 检查数组中是否存在某个值
key -- 从结合数组中取得键名
krsort -- 对数组按照键名逆向排序
ksort -- 对数组按照键名排序
list -- 把数组中的值赋给一些变量
natcasesort -- 用“自然排序”算法对数组进行不区分大小写字母的排序
natsort -- 用“自然排序”算法对数组排序
next -- 将数组中的内部指针向前移动一位
pos -- 得到数组当前的单元
prev -- 将数组的内部指针倒回一位
range -- 建立一个包含指定范围单元的数组
reset -- 将数组的内部指针指向第一个单元
rsort -- 对数组逆向排序
shuffle -- 将数组打乱
sizeof -- count() 的别名
sort -- 对数组排序
uasort -- 使用用户自定义的比较函数对数组中的值进行排序并保持索引关联
uksort -- 使用用户自定义的比较函数对数组中的键名进行排序
usort -- 使用用户自定义的比较函数对数组中的值进行排序
‘伍’ 打乱数组顺序
没有太理解这道题的中心思想是什么,要求是打乱数组的缓孝仔排列顺序,返回每种排列的概扰汪率都一样。
示例:
// 以数字集合 1, 2 和 3 初始化数组。
int[] nums = {1,2,3};
Solution solution = new Solution(nums);
// 打乱数组 [1,2,3] 并返回结果。任何 [1,2,3]的排列返回的概率应该相同。
solution.shuffle();
// 重设数组到它的初始状态[1,2,3]。
solution.reset();
// 随机返回数组[1,2,3]打乱后的结果。
solution.shuffle();
做法倒也慎搭是不难,重设数组就返回原数组就完了,随机返回打乱数组就:
1.从N个数中随机取一个数放在第一个位置
2.从剩下N-1个数中随机取一个数放在第二个位置。
3.依次放完每一个数。
class Solution {
private int[] nums;
private int[] originalNums;
public Solution(int[] nums) {
this.nums = nums;
this.originalNums = Arrays.Of(nums, nums.length);
}
public int[] reset() {
return this.originalNums;
}
public int[] shuffle() {
Random random = new Random();
int len= nums.length;
while (len> 1) {
int k = random.nextInt(len);
//这里可以合并成swap(nums, --len, k);
swap(nums, len- 1, k);
len--;
}
return nums;
}
private void swap(int[] nums, int i, int j) {
int tmp = nums[i];
nums[i] = nums[j];
nums[j] = tmp;
}
}
‘陆’ php删除数组中的一个元素,其他元素的顺序会改变吗
顺序的话,少了一个肯定向前啊。
如果是键值,那么键值也不会改变。
(好像你在排队一下,少一个人肯定后面的向前走,不会出现什么顺序打乱之类的。)
如果你用的特定函数,比如array_shift() 函数的话(并且键值是自己设定的话,就不会改变键名;如果自动生成,会帮你重新排列键名,顺序不管怎么样都不会打乱,最多就是键名打断;除非这个函数说了,会随即打乱排序,那就会打乱咯。)
-----------
不采纳?我继续补充~
例如:
键值:1 2 3 4 5
对应:A B C D E
如果我用unset 删除了键值为4的D,那么,数组的排序就是:
键值:1 2 3 5
对应:A B C E
也就是少了一个数
如果这回我用的array_shift()函数删除键值为4的D,结果就是:
键值:0 1 2 3
对应:A B C E
它自动从0开始把键值重新排序。
如果不出意外的情况下,键值是直接对应具体的值的。也就说,键值位置的改变,值也会设置而变。
求采纳T_T
‘柒’ 如何将php数组,打乱顺序并定位
用一个数组存资料,再用随机数控制数组下标来做
‘捌’ 如何打乱一组数的顺序
方法一: 把这10个数字写成10个卡片,像洗扑克牌一样打乱,随便抽。
方法二:把这10个数编号银激,然后用random得到1到10之间的一个此搏悉随机数n1,将编号为n1的的数排在第一森乎,然后将剩余的9个数从1到9排序,用random得到1到9之间的一个随机数n2,将编号为n2的的数排在第二,依次类推。
‘玖’ php中给出一组数组,要求把这组数据打乱顺序后输出,而且不能重复!!请高手帮忙呀!
你要代码还是算法啊?
我就直接说下大概算法好了
假设有个数组里面有10个数字
然后你来个循环,10个数字10次也差不多了
for($i=0;$i<10;$i++){
$a1=rand(0,9);//随机0到9的数字的
$a2=rand(0,9);
/*
*其实就是调换2个数字
*/
$j=$array[$a1];
$array[$a1]=$array[$a2];
$array[$a2]=$j;
}
循环十次,基本都打乱了,你的打乱没什么要求,所以这样应该符合要求了
‘拾’ php的数组怎么打乱顺序
shuffle — 将数组打乱