日期:2014-05-16  浏览次数:20585 次

PHP数组问题,求助!
有这样一个数组:
$array = array (
  0 => 
  array (
    'day' => '2014-3-11',
    'count' => 4,
    'day_0' => 3,
    'day_1' => 1,
  ),
  1 => 
  array (
    'day' => '2014-3-7',
    'count' => 2,
    'day_0' => 1,
  ),
  2 => 
  array (
    'day' => '2014-3-6',
    'count' => 4,
    'day_4' => 1,
    'day_5' => 1,
  ),
  3 => 
  array (
    'day' => '2014-3-10',
    'count' => 10,
    'day_0' => 7,
    'day_1' => 2,
    'day_2' => 1,
  ),
);
日期间隔不固定,这里示例是2014-3-6 至2014-3-11,中间间隔五天,想通过对日期的排序和间隔的天数,得到如下数组:


补充:
3月6日与3月11日相差5天,所以3月6日就有day_1、day_2、day_3、day_4、day_5
3月7日与3月11日相差4天,所以3月7日就有day_1、day_2、day_3、day_4
3月8日与3月11日相差3天,所以3月8日就有day_1、day_2、day_3
3月9日与3月11日相差2天,所以3月9日就有day_1、day_2
3月10日与3月11日相差1天,所以3月10日就有day_1
3月11日与3月11日相差0天,所以没有day_……
……依次类推,得出一个类似三角型的数组

请大家帮帮忙吧!!!感谢!
------解决方案--------------------
foreach($array as $v){
   $days[]=date("Ymd",strtotime($v['day']));
   $ar[date("Ymd",strtotime($v['day']))]=$v;
}   
$arr= range(min($days),max($days));
$max = max($arr);
foreach($arr as $v){
    $d = $max-$v;
    if(isset($ar[$v])){
     $tt[$v]['day']=$ar[$v]['day'];
 $tt[$v]['count']=$ar[$v]['count'];
 for($i=1;$i<=$d;$i++) $tt[$v]['day_'.$i]=(int)$ar[$v]['day_'.$i];
}else{
     $tt[$v]['day']=date("Y-m-j",strtotime($v));
 $tt[$v]['count']=0;
 for($i=1;$i<=$d;$i++) $tt[$v]['day_'.$i]=0;
}
}
print_r(array_values($tt));