오늘 직장에서 ThoughtWorks 면접 질문을 발견했는데 공유해보겠습니다
풀어 주다: 2016-07-25 08:48:14
可以接受任意多个特殊数(不包含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