今天上班發現一個ThoughtWorks的面試問題,分享一下
可以接受任意多个特殊数(不包含0),在任意数字范围内输出(1~xxx) 其实还可以用策略模式吧算法独立出来 针对这个题目就先不写了 (偷懒~~)
- class FizzBuzzWhizz{
- private $_special=array();
- private $_words=array();
- public function __construct(array $special,array $words){
- if(in_array(0,$special)){
- exit('特殊数中不能含有0');
- }
- $this->_special=$special;
- $this->_words=$words;
- }
- public function run($num){
- $output='';
- for($i=1;$i<=$num;$i ){
- $output.=$this->_calculate($i);
- }
- echo $output;
- exit();
- }
- private function _calculate($number){
- $str='';
- if(strpos($number,$this->_special[0]) > 0){
- return $this->_words[0]."
";
- }
- foreach($this->_special as $k=>$v){
- if($number%$v === 0){
- $str.=$this->_words[$k];
- }
- }
- return $str==''?$number.'
': $str.' ';
- }
- }
-
- $special=array(3,5,7);
- $words=array('Fizz','Buzz','Whizz');
- $obj=new FizzBuzzWhizz($special,$words);
- $obj->run(100);
复制代码
|
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
-
2024-10-22 09:46:29
-
2024-10-13 13:53:41
-
2024-10-12 12:15:51
-
2024-10-11 22:47:31
-
2024-10-11 19:36:51
-
2024-10-11 15:50:41
-
2024-10-11 15:07:41
-
2024-10-11 14:21:21
-
2024-10-11 12:59:11
-
2024-10-11 12:17:31