Dam*_*ian 8 ruby operators fizzbuzz conditional-operator
我一直在阅读ruby中的条件样式表达式.但是我遇到了一个我无法理解的定义经典FizzBuzz问题.我理解FizzBuzz问题,甚至在使用三元运算符找到以下快速解决方案之前编写了自己的问题.如果有人可以向我解释这个链如何工作以满足FizzBuzz问题,那将非常感谢:)
for i in 0...100
puts i%3==0 ? i%5==0 ? "FizzBuzz" : "Buzz" : i%5==0 ? "Fizz" : i
end
Run Code Online (Sandbox Code Playgroud)
Gre*_*ill 16
一些括号可能会有所帮助:
puts (i%3 == 0) ? ((i%5 == 0) ? "FizzBuzz" : "Buzz") : ((i%5 == 0) ? "Fizz" : i)
Run Code Online (Sandbox Code Playgroud)
因此,如果我可以被3整除,那么它会检查我是否也可以被5整除.如果是这样,它会打印"FizzBuzz",否则只是"Buzz".如果我不能被3整除,那么它再次检查5的可分性并打印"Fizz",如果是,否则只是我.
Jor*_*ira 11
以下是Jeff Atwood这篇文章中对FizzBuzz问题的描述.
编写一个程序,打印从1到100的数字.但是对于三个的倍数打印"Fizz"而不是数字和五个打印"Buzz"的倍数.对于三和五的倍数的数字打印"FizzBuzz".
一个三元操作符是一个if-else语句速记记录.一般格式是:
cond ? evaluate_if_cond_is_true : evaluate_if_cond_is_false
所以,如果我写:
int isEven = (i % 2 == 0) ? 1 : 0;
Run Code Online (Sandbox Code Playgroud)
相当于以下代码:
if (i % 2 == 0) {
isEven = 1;
} else {
isEven = 0;
}
Run Code Online (Sandbox Code Playgroud)
cond是i % 2 == 0,evaluate_if_cond_is_true是1和evaluate_if_cond_is_false是0.
三元运算符的好处在于它们可以组合在一起.这意味着当条件计算为true或false时要执行的语句可以是另一个三元运算符.
让整个条件更具可读性:
i%3==0 ?
i%5==0 ?
"FizzBuzz"
: "Buzz"
: i%5==0 ?
"Fizz"
: i
Run Code Online (Sandbox Code Playgroud)
使用上面解释的规则将其映射到if-else语句很容易:
if (i%3==0) {
if (i%5==0) {
"FizzBuzz"
} else {
"Buzz"
}
} else {
if (i%5==0) {
"Fizz"
} else {
i
}
}
Run Code Online (Sandbox Code Playgroud)
这不是有效的代码,但因为三元运算符的结果在结果表达式中内联,所以它被用作puts命令的输入.
为了好玩,这是另一种方式:
puts (1..100).map {|i| (fb = [["Fizz"][i%3],["Buzz"][i%5]].compact.join).empty? ? i : fb}
Run Code Online (Sandbox Code Playgroud)
而另一个:
(1..100).zip([nil,nil,"Fizz"]*34,[nil,nil,nil,nil,"Buzz"]*20).map {|a,b,c| b || c ? [b,c].join : a}
Run Code Online (Sandbox Code Playgroud)