我在检查时间范围时遇到了问题。
实施例
<?php
$starthour = '08'; //Starting work hour
$finishhour = '23'; //Finishing work hour
$extrapaidhours = 0; //Counting extrapaying hours
if($starthour <= 5) {
if($starthour==5) { $extrapaidhours += 5; }
else { $extrapaidhours += 5 - $starthour; }
}
if($starthour > 22) {
$extrapaidhours += 24 - $starthour;
}
if($finishhour <= 5) {
if($finishhour==5) { $extrapaidhours += 5; }
else { $extrapaidhours += 5 - $finishhour; }
}
if($finishhour > 22) {
$extrapaidhours += 24 - $finishhour;
}
echo $extrapaidhours;
我有点堆积,我认为我的逻辑做错了。 我正试图让时间在22-05之间。
也许有人从21:00到05:00开始工作,他在这个范围内有超时工作时间,从22:00到05:00为7小时。
我该如何处理这件事。谢谢大家。
答案 0 :(得分:0)
这是一种可能的解决方案。
我们必须考虑两种不同的情况:
首先:$starthour < $finishhour -> $starthour
和$finishhour
是在同一天
第二个:$starthour > $finishhour -> $starthour
和$finishhour
分为两个不同的日子
此解决方案仅使用一个if
/ else
语句和max
/ min
函数
<?php
$starthour = '08'; //Starting work hour
$finishhour = '23'; //Finishing work hour
$extrapaidhours = 0; //Counting extrapaying hours
if ($starthour < $finishhour)
$extrapaidhours += (min($finishhour,5)-min($starthour,5))
+ (max($finishhour,22)-max($starthour,22));
else
$extrapaidhours += (5-min(5,$starthour))
+ (24-max(22,$starthour))
+ min(5,$finishhour)
+(max($finishhour,22)-22);
echo $extrapaidhours;
?>
答案 1 :(得分:0)
我喜欢玩不太流行的PHP函数和非标准方法:)
<?php
$start_hour = '19'; //Starting work hour
$finish_hour = '08'; //Finishing work hour
$extra_paid_hours = array(22, 23, 0, 1, 2, 3, 4, 5); //list of extra paid hours
if ($start_hour <= $finish_hour) {
$hours = range(intval($start_hour), intval($finish_hour));
} else {
$hours = array_merge(range(intval($start_hour), 23), range(0, intval($finish_hour)));
}
$extra_paid_hours_count = array_reduce($hours, function($accum, $hour) use($extra_paid_hours) {
$accum += in_array($hour, $extra_paid_hours) ? 1 : 0;
return $accum;
}, 0);
echo $extra_paid_hours_count;