Maison >développement back-end >tutoriel php >php生成随机颜色,并且相邻元素颜色不同
php 随机 php 随机
如题,是这种布局形式 把规则再说清楚一些
所谓 相邻元素颜色不同 4和5是相邻的吗?如果是,仅有的6种颜色无法实现.重新描述下你的需求...如果不是,那你定义下你这里"相邻元素"的概念
把规则再说清楚一些
所谓 相邻元素颜色不同 4和5是相邻的吗?如果是,仅有的6种颜色无法实现.重新描述下你的需求...如果不是,那你定义下你这里"相邻元素"的概念
嗯,4,5是相邻的。。6种无法实现的话,可以增加的。
1 2 3
4 5 1
2 3 6
这个符合要求吗?
把规则再说清楚一些
所谓 相邻元素颜色不同 4和5是相邻的吗?如果是,仅有的6种颜色无法实现.重新描述下你的需求...如果不是,那你定义下你这里"相邻元素"的概念
嗯,4,5是相邻的。。6种无法实现的话,可以增加的。
限定使用有限种颜色和不限定颜色种类 实现起来应该是(可以)不一样的 前者是有限种可以计算出来 后者可以直接随机取然后判断如果不行再次随机取
1 2 1
3 4 3
1 2 1
四色地图?
算法我弱啊
我的想法是从左向右、从上向下遍历,填入数字(1~n),只要前面相邻(横竖斜)的格子出现过就跳过,没出现就选这个数
例如右上角,因为还没到第二行,相邻的就只有左边一个格子2,所以1~n中,1就直接符合了,填入右上角
1 2 3
4 5 1
2 3 6
这个符合要求吗?
这样符合的,但是这个样式是通过瀑布流加载的。高度不固定,所以很纠结。有可能中间的2 5 3都跟1接近!
1 2 3
4 5 1
2 3 6
这个符合要求吗?
页面使用的是masonry和infinitescroll,每排三个块,宽度固定,高度不定。然后要实现相邻的背景色不同,不知道具体如何实现呢?
如果#5也符合要求的话,那可以跟你说:单数行是1 2 1,双数行是3 4 3……循环就是了
$d = array(1,2,3,4,5,6);$a = array($d[rand(0, 5)]);$loop = 300; //用于防止死循环while(count($a) < 210 && $loop--) { $p = count($a); $n = $d[0]; $d[] = array_shift($d); switch($p % 3) { case 1: if($a[$p-1] == $n) continue; if(isset($a[$p-3]) && $a[$p-3] == $n) continue; $a[] = $n; break; case 2: if($a[$p-1] == $n) continue; if(isset($a[$p-2]) && $a[$p-2] == $n) continue; if(isset($a[$p-3]) && $a[$p-3] == $n) continue; if(isset($a[$p-6]) && $a[$p-6] == $n) continue; if(isset($a[$p-8]) && $a[$p-8] == $n) continue; $a[] = $n; break; case 0: if(isset($a[$p-3]) && $a[$p-3] == $n) continue; if(isset($a[$p-4]) && $a[$p-4] == $n) continue; if(isset($a[$p-6]) && $a[$p-6] == $n) continue; $a[] = $n; break; }// $a[] = $n; //如果从case中移到这里,将导致错误结果!BUG}$t = array_map(function($r){ return join(',', $r);}, array_chunk($a, 3));print_r($t);Array