需求是這樣 ...
if ( $foo > 0 && $foo < 100 ) $bar = 1;
elseif ( $foo > 99 && $foo < 212 ) $bar = 2;
elseif ( $foo > 211 && $foo < 324 ) $bar = 3;
elseif ( $foo > 323 && $foo < 382 ) $bar = 4;
elseif ( $foo > 381 && $foo < 465 ) $bar = 5;
elseif ( $foo > 464 && $foo < 552 ) $bar = 6;
# ...
這樣的規則有上千條 ... 于是滿屏幕都是 $foo > __ && $foo < __ $bar = __ ...
效率和美觀都成問題 ...
臨界點的數值近乎隨機 ... 我想不到可以通過 $foo 推算 $bar 的公式 ...
目前的想法是把所有的規則二分掉 ... 這樣可以提高效率 ... 但美觀依然是問題 ...
如果封在一個函數里 ... 看上去似乎確實美觀一些 ... 但效率反而不如這樣 ...
有沒有什么兩者兼顧的比較完美的解決方案 ..?
追加 ... 自己寫了一個借助數組排序的方案 ...
效率和自己實現函數差不多 ... 依然不如二分 ...
第一種方法
假設你的范圍是之間是連續的(其實不連續也很容易實現)、沒有重合的(這個沒問題吧),那么通過對范圍的起始位置排序,就可以很容易地用二分來實現。
$ranges = array(1, 100, 212, 324, 382, 465, 552);
然后你要做的事情就是用二分查找在ranges里面找到一個a[i]滿足a[i] <= t && t < a[i+1]。
第二種方式
<?phpfunction sorts($stage_data,$stage_num) {array_push($stage_data,$stage_num);$data = array_unique($stage_data);//asort($data);sort($data);//var_dump($data);return array_search($stage_num,$data);}$stage_data = array(0,26,51,76,100);$stage_num = 16;echo sorts($stage_data,$stage_num);//res:1?>
數據量大的時候個人沒有做測試,不知道那種性能最優!
新聞熱點
疑難解答
圖片精選