当前位置:Gxlcms > PHP教程 > php生成随机颜色,并且相邻元素颜色不同

php生成随机颜色,并且相邻元素颜色不同

时间:2021-07-01 10:21:17 帮助过:19人阅读

php 随机 php 随机

如题,是这种布局形式
1 2 3
4 5 6
7 8 9
相邻元素颜色不同,还有就是,比如5的话,跟1 3 7 9 的颜色也要不同,请问这个如何实现,生成随机颜色可以的,但是颜色不同如何实现呢。备选的颜色大概6种。谢谢


回复讨论(解决方案)

把规则再说清楚一些

所谓 相邻元素颜色不同 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
(
[0] => 1,2,3
[1] => 4,5,6
[2] => 2,3,4
[3] => 5,6,1
[4] => 3,4,5
[5] => 6,1,2
[6] => 4,5,6
[7] => 1,2,3
[8] => 5,6,1
[9] => 2,3,4
[10] => 6,1,2
[11] => 3,4,5
[12] => 1,2,3
[13] => 4,5,6
[14] => 2,3,4
[15] => 5,6,1
[16] => 3,4,5
[17] => 6,1,2
[18] => 4,5,6
[19] => 1,2,3
[20] => 5,6,1
[21] => 2,3,4
[22] => 6,1,2
[23] => 3,4,5
[24] => 1,2,3
[25] => 4,5,6
[26] => 2,3,4
[27] => 5,6,1
[28] => 3,4,5
[29] => 6,1,2
[30] => 4,5,6
[31] => 1,2,3
[32] => 5,6,1
[33] => 2,3,4
[34] => 6,1,2
[35] => 3,4,5
[36] => 1,2,3
[37] => 4,5,6
[38] => 2,3,4
[39] => 5,6,1
[40] => 3,4,5
[41] => 6,1,2
[42] => 4,5,6
[43] => 1,2,3
[44] => 5,6,1
[45] => 2,3,4
[46] => 6,1,2
[47] => 3,4,5
[48] => 1,2,3
[49] => 4,5,6
[50] => 2,3,4
[51] => 5,6,1
[52] => 3,4,5
[53] => 6,1,2
[54] => 4,5,6
[55] => 1,2,3
[56] => 5,6,1
[57] => 2,3,4
[58] => 6,1,2
[59] => 3,4,5
[60] => 1,2,3
[61] => 4,5,6
[62] => 2,3,4
[63] => 5,6,1
[64] => 3,4,5
[65] => 6,1,2
[66] => 4,5,6
[67] => 1,2,3
[68] => 5,6,1
[69] => 2,3,4
)
任何连续三行都将满足你的需要

弄了几天,终于发现一个 php 的 bug
还是比较满意的

如果基本的语法结构都会出现问题的话,php 到了该进坟墓的时候了!

人气教程排行