今天上班发现一个ThoughtWorks的面试题,分享一下
Lepaskan: 2016-07-25 08:48:14
asal
1440 orang telah melayarinya
可以接受任意多个特殊数(不包含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);
复制代码
|
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
-
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
Topik-topik yang berkaitan
Lagi>