今天上班发现一个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 $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