迭代多个数组并分配位置

时间:2013-10-25 16:11:38

标签: php arrays

已经工作了4个小时。我的眼睛开始受伤,我的大脑因悖论而疲惫不堪。

所以这是设置。 3个阵列:

  • 作为广告的帖子数组

  • 一系列普通帖子

  • 从阵列1中拉出的一系列采取位置

广告数组包含预定义的广告位。

我合并了2个阵列,因为广告基本上已整合到正常的帖子流中。我甚至能够根据帖子的自然顺序和广告的指定位置为每个帖子分配一个位置。因此,如果帖子的自然广告中有广告,那么该帖子的位置需要向前推进一个广告。如果流中只有一个广告,这很容易。但是为多个任意数量的广告设置了这个东西。

所以这就是我如何碰撞数组中每个非广告元素的位置。我认为我可以再次运行这几次,这应该包含在有其他广告时,但它似乎是错误的和不圣洁的。

想知道是否有人能解决这个问题,因为我厌倦了自己的眼泪。

if(in_array($newarray[$key]['position'],$taken)){ 

$newkey = ($newarray[$key]['position'] + 1);
$newarray[$key]['position'] = $newkey;
$taken[] = $newkey;

最后,我需要合并的数组,所有位置都正确分配并且唯一。

1 个答案:

答案 0 :(得分:1)

您可以编写一个递归函数来提取下一个可用的位置编号,但如果您正在使用少量的帖子+广告,那么下面的内容就会快速而简单。请注意,这假设您需要保留广告和帖子数组的原始密钥。如果您不需要这样做,那么您可以进一步简化它。

// Sample array of ads
$ads = array('ad1' => array('position' => 1),
             'ad2' => array('position' => 4),
             'ad3' => array('position' => 6),
             'ad4' => array('position' => 10));
// Identify ad positions
foreach ( $ads as $k => $v ) {
    $adPositions[$v['position']] = $v['position'];
}
// Identify available positions
$availablePositions = array_combine(range(1,100), range(1,100));
$availablePositions = array_diff_key($availablePositions, $adPositions);
// Sample posts
$posts = array('post1' => array('position' => false),
               'post2' => array('position' => false),
               'post3' => array('position' => false),
               'post4' => array('position' => false),
               'post5' => array('position' => false),
               'post6' => array('position' => false));
// Use first (lowest number) available position as post position
foreach ( $posts as $k => $v ) {
    $posts[$k]['position'] = array_shift($availablePositions);
}
// Merge arrays
$merged = array_merge($ads, $posts);
// Create list of positions for use with array_multisort
foreach ( $merged as $k => $v ) {
    $position[$k] = $v['position']; 
}
// Sort $merged by ['position']
array_multisort($position, SORT_ASC, $merged);

给你:

Array
(
    [ad1] => Array
        (
            [position] => 1
        )

    [post1] => Array
        (
            [position] => 2
        )

    [post2] => Array
        (
            [position] => 3
        )

    [ad2] => Array
        (
            [position] => 4
        )

    [post3] => Array
        (
            [position] => 5
        )

    [ad3] => Array
        (
            [position] => 6
        )

    [post4] => Array
        (
            [position] => 7
        )

    [post5] => Array
        (
            [position] => 8
        )

    [post6] => Array
        (
            [position] => 9
        )

    [ad4] => Array
        (
            [position] => 10
        )

)