所以我有这个代码......(我很抱歉)
(我需要更多"详细信息"在我的问题中,因为代码太长了) 基本上它需要用户拥抱计数,并且每隔一段时间它会给他们一个新的报价作为奖励,但间隔是不规则的。
if ($hugs > 0) {
$quote = $quotes[0];
}
if ($hugs > 5) {
$quote = $quotes[1];
}
if ($hugs > 10) {
$quote = $quotes[2];
}
if ($hugs > 20) {
$quote = $quotes[3];
}
if ($hugs > 50) {
$quote = $quotes[4];
}
if ($hugs > 100) {
$quote = $quotes[5];
}
if ($hugs > 150) {
$quote = $quotes[6];
}
if ($hugs > 200) {
$quote = $quotes[7];
}
if ($hugs > 250) {
$quote = $quotes[8];
}
if ($hugs > 500) {
$quote = $quotes[9];
}
if ($hugs > 750) {
$quote = $quotes[10];
}
if ($hugs > 1000) {
$quote = $quotes[11];
}
if ($hugs > 1500) {
$quote = $quotes[12];
}
由于拥抱计数之间的间隔是不规则的,有没有办法将其浓缩下来?
TIA。
答案 0 :(得分:3)
你当然可以压缩它!一种方法是构建一个关联数组(键值对),如下例所示。
/**
* Returns a quote based on the number of hugs
*
* @param int $hugs
* @param array $quotes
*
* @return string|null
*/
function getQuoteFromHugs($hugs, $quotes) {
$hugs_quotes = array(
1500 => $quotes[12],
1000 => $quotes[11],
750 => $quotes[10],
500 => $quotes[9],
250 => $quotes[8],
200 => $quotes[7],
150 => $quotes[6],
100 => $quotes[5],
50 => $quotes[4],
20 => $quotes[3],
10 => $quotes[2],
5 => $quotes[1],
0 => $quotes[0],
);
foreach($hugs_quotes as $hug_minimum => $quote) {
if($hugs > $hug_minimum) {
return $quote;
}
}
return null;
}
// Usage
$quote = getQuoteFromHugs($hugs, $quotes);
按顺序遍历每个键值配对,并查看$ hugs参数是否大于键。如果是,则返回与该键关联的值。
答案 1 :(得分:2)
这样的事情:
$steps = array(0, 5, 10, 20, 50, 100, 150, 200, 250, 500, 750, 1000, 1500);
foreach ($steps as $index => $step) {
if ($hugs > $step) {
$quote = $quotes[$index];
}
}
这使用$steps
数组将$quotes
数组中的索引映射到下一步。
答案 2 :(得分:1)
以下是组织它的方法:
function getQuote($hugs) {
$hugQuotes = array(
array(1500, $quotes[12]),
array(1000, $quotes[11]),
...
);
foreach($hugQuotes as $v) {
$c = $v[0];
$quote = $v[1];
if ($hugs > $c) return $quote;
}
return $quote;
}