Heim >Backend-Entwicklung >PHP-Tutorial >php生成随机颜色,并且相邻元素颜色不同

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

WBOY
WBOYOriginal
2016-06-23 14:21:001037Durchsuche

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

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn