本文实例讲述了php组合排序简单实现方法。分享给大家供大家参考,具体如下:
今天被一个组合排序纠结了一晚上,可能是开始没转过弯,所以没想到用二个栈。用了二个栈就很简单的完成了需求效果
组合排序想象图
为了完成这个效果图,可纠结死我了,先用sql组合查询,结果是组合了,但是效果达不到。现在贴出PHP代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
//获取学生信息 private function ground( $data ) { $stu = array (); //新建一个学号栈,存储学生学号 foreach ( $data as $key => $value ) { if (in_array( $value [ "studentid" ], $stu )) //判断学号是不是已经被存储 { array_push ( $array [ $value [ "studentid" ]], $value [ "selectbh" ]); //入栈 array_push ( $array [ $value [ "studentid" ]], $value [ "taskid" ]); //入栈 } else { // 动态新建学生信息栈。 $array [ $value [ "studentid" ]] = array ( $value [ 'selectbh' ], $value [ 'taskid' ]); array_push ( $stu , $value [ "studentid" ]); //再学号栈里面没有的学号入栈 } } unset( $stu ); //注销学号栈 return $array ; //返回学生信息节点 } |
就上面的代码,就可以做到我们想的效果了,预览这个页面得到下面的效果
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
array (2) { [ "10408400227" ] => array (4) { [0] => string(1) "1" [1] => string(1) "4" [2] => string(1) "2" [3] => string(1) "5" } [ "10408400229" ] => array (6) { [0] => string(1) "1" [1] => string(1) "4" [2] => string(1) "2" [3] => string(2) "28" [4] => string(1) "3" [5] => string(2) "14" } } |
形成了一个二维数组,用学号做了数组的键,这样就关联了学号,可以得到对于的效果图了。
希望本文所述对大家PHP程序设计有所帮助。