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) 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 到了该进坟墓的时候了!