首页 > php的数学题

php的数学题

我有一个数组,里面存的每一个都是一个年月日的日期的时间戳,
类似如下

$data_arr = array(
    strtotime("2015-08-01"),
    strtotime("2015-08-02"),
    strtotime("2015-08-03"),
    strtotime("2015-08-04"),
    strtotime("2015-08-05"),
    strtotime("2015-08-07"),
    strtotime("2015-08-09"),
    strtotime("2015-08-10"),
    strtotime("2015-08-13")
);

这里面存放的是一个用户某一天没有交费。
现在希望能展示成

2015-08-01 到 2015-08-05 未交费
2015-08-07 未交费
2015-08-09 到 2015-08-10 未交费
2015-08-13 未交费

类似的就是这个意思,
请问应该如何处理数组呢?


先排序,再遍历一遍


你的问题是一个数组里面保存着一些时间戳,你需要格式化一下这些数据对吧。我建议的方案:首先把时间戳转为具体日期年月日,分割年份,月份,日期出来组装好一个多维数组;然后日期间对比是否相邻,月份和年份对比则是最后一天和最早一天是否相邻,符合相邻条件的把数组连接起来组成新的数组,大概就这么一个思路,由于存在不同年不同月的情况,所以可能会复杂一点,大概需要写一个二次遍历才行,希望能帮到你…


上面那位朋友运行报了notice错误(数组越界),试试我的代码

<?php
$data_arr = array(
    strtotime("2015-08-01"),
    strtotime("2015-08-03"),
    strtotime("2015-08-04"),
    strtotime("2015-08-05"),
    strtotime("2015-08-06"),
    strtotime("2015-08-07"),
    strtotime("2015-08-09"),
    strtotime("2015-08-10"),
    strtotime("2015-08-13"),
    strtotime("2015-08-14"),
    strtotime("2015-08-15"),
    strtotime("2015-08-19"),
    strtotime("2015-08-20"),
    strtotime("2015-08-22"),
);
array_push($data_arr, null);
        $start=null;
        for($i=1;$i<count($data_arr);$i++){
        if($data_arr[$i]==$data_arr[$i-1]+24*3600){
            if(!$start){
                $start=$data_arr[$i-1];
            }
        }else{
            if($start){
                echo date("Y-m-d",$start)."到".date("Y-m-d",$data_arr[$i-1])."未付款\n";
            }else{
                echo date("Y-m-d",$data_arr[$i-1])."未付款\n";
            }
            $start=null;
        }
        }
?>

献丑了


先把时间全部转化成unix时间戳,然后对数组做一次数字升序排序.然后设置起始时间后,不断跟后一个数来比对,是否相差1天,如果是则不断更新对应的结束时间,如果否则设置结束时间,并另外设置一个新的起始时间,你复制下我的代码跑下,就明白了.顺带说下,这段代码至少要php5.4以上的版本才能跑通,短数组语法只从5.4开始支持.望采纳

$data_arr = array(
    strtotime("2015-08-01"),
    strtotime("2015-08-02"),
    strtotime("2015-08-03"),
    strtotime("2015-08-04"),
    strtotime("2015-08-05"),
    strtotime("2015-08-07"),
    strtotime("2015-08-09"),
    strtotime("2015-08-10"),
    strtotime("2015-08-13")
);
sort($data_arr);
$vars = [];//大致的数据是key若为奇数,则为开始时间,若key为偶数则为结束时间
$vars[] = $data_arr[0];//开始时间
for ($i=0;$i<count($data_arr);$i++)
{
    if (isset($data_arr[$i+1]) && ($data_arr[$i]+86400) == $data_arr[$i+1]) continue;
    else {
        $vars[] = $data_arr[$i];
        if (isset($data_arr[$i+1])) $vars[] = $data_arr[$i+1];
    }

}
foreach ($vars as $var)
{
    echo date("Y-m-d",$var),"<br />";
}

前面一位朋友的程序运行了下,结果不是题主要的那种形式。请看我的程序。

<meta charset="utf-8">
<?php
$data_arr = array(
    strtotime("2015-08-01"),
    strtotime("2015-08-03"),
    strtotime("2015-08-04"),
    strtotime("2015-08-05"),
    strtotime("2015-08-06"),
    strtotime("2015-08-07"),
    strtotime("2015-08-09"),
    strtotime("2015-08-10"),
    strtotime("2015-08-13"),
    strtotime("2015-08-14"),
    strtotime("2015-08-15"),
    strtotime("2015-08-19"),
    strtotime("2015-08-20"),
    strtotime("2015-08-22"),
);
for ($i = 0; $i < count($data_arr); $i++) {
    if ($data_arr[$i - 1] + 24 * 3600 == $data_arr[$i] && $data_arr[$i + 1] - 24 * 3600 != $data_arr[$i]) {
        $end = $data_arr[$i];
        echo date("Y-m-d", $start) . "到" . date("Y-m-d", $end) . "未交费<br>";
    } 
    if ($data_arr[$i + 1] - 24 * 3600 == $data_arr[$i] && $data_arr[$i - 1] + 24 * 3600 != $data_arr[$i]) {
        $start = $data_arr[$i];
    }
    if ($data_arr[$i + 1] - 24 * 3600 != $data_arr[$i] && $data_arr[$i - 1] + 24 * 3600 != $data_arr[$i]) {
        echo date("Y-m-d", $data_arr[$i]) . "未交费<br>";
    }
}
?>

运行结果

2015-08-01未交费
2015-08-03到2015-08-07未交费
2015-08-09到2015-08-10未交费
2015-08-13到2015-08-15未交费
2015-08-19到2015-08-20未交费
2015-08-22未交费
【热门文章】
【热门文章】