2015-03-13 64 views
-1

有一个问题,我花了一些时间来找出解决方案。如何在数字范围内找到可用的批次php

有一个主号码批次。例如100-150(大小-51)。 并且该主批次中还有少量子批次。例如105 - 110和120 - 130.

我想在主批次中获得其他批次及其批量大小。 例如 100-104,111-119和131-150

我试图找到解决方案,但尚未找到任何解决方案。有没有人可以指导我在php中做这个或给伪代码,这对我会非常有帮助。

感谢

+1

也许如果你给一些真正的PHP数据结构的一些实际例子这将是我们更容易找出你的意思 – 2015-03-13 10:08:55

+0

请提供您想出或代码应该如何呈现(组成代码)。记住,我们不是自由工人。 ;) – 2015-03-13 10:08:57

+0

其实我想要一些指导来解决这个问题。其实我没有任何想法来实现这一点。 – cha 2015-03-13 10:14:36

回答

1

使用array_diff,你可以找到你批次阵列中的自由空间。

然后从这个列表中提取没有按键中断的部分,导致每个空闲的范围离开。

$mainBatch = range(100, 150); 

$subBatch = range(110, 120); 
$subBatch2 = range(130,145); 

$subBatchesFree = array_diff($mainBatch, $subBatch, $subBatch2); 

$remainingBatches = array(); 
$i = 0; 
foreach ($subBatchesFree as $key => $available) { 
    if (isset($subBatchesFree[$key + 1])) { 
     // Next key is still in the range 
     ++$i; 
    } else { 
     // Next key is in a new range. 
     // I create the current one and init for the next range 
     $remainingBatches[] = range($subBatchesFree[$key - $i], $available); 
     $i = 0; 
    } 
} 

print_r($remainingBatches); 

输出:

Array 
(
    [0] => Array 
     (
      [0] => 100 
      [1] => 101 
      [2] => 102 
      [3] => 103 
      [4] => 104 
      [5] => 105 
      [6] => 106 
      [7] => 107 
      [8] => 108 
      [9] => 109 
     ) 

    [1] => Array 
     (
      [0] => 121 
      [1] => 122 
      [2] => 123 
      [3] => 124 
      [4] => 125 
      [5] => 126 
      [6] => 127 
      [7] => 128 
      [8] => 129 
     ) 

    [2] => Array 
     (
      [0] => 146 
      [1] => 147 
      [2] => 148 
      [3] => 149 
      [4] => 150 
     ) 

) 
+0

有无论如何创建动态subBath数组并传递参数? – cha 2015-03-17 11:42:13

+0

@Cha你的意思是'array_diff'? – Sugar 2015-03-17 12:58:47

+0

是的。我可以创建subBatches的数组。但那些是动态数组。因此我试图找到一种方法将它们作为参数传递给array_diff。我刚才找到了一个解决方案。 call_user_func_array('array_diff',$ this-> array_of_arrays);这是正确的方法吗? – cha 2015-03-17 13:18:03

相关问题