所以,Fizz Buzz 是一个非常简单的问题,这个问题有很多解决方案。在最近的一次采访中,面试官让我为 Fizz Buzz 写一个函数,所以我一手想出了以下方法。
void fizz_buzz(int range) {
for(auto i = 1; i < range; ++i) {
if(i % 15 == 0)
cout << "FizzBuzz" << "\n";
else if(i % 3 == 0)
cout << "Fizz" << "\n";
else if(i % 5 == 0)
cout << "Buzz" << "\n";
else
cout << i << "\n";
}
}
Run Code Online (Sandbox Code Playgroud)
然后面试官问我如果我想修改 3 和 7 的 Fizz Buzz 那么在你的代码中多个条件语句将不得不更改。
所以,我写了以下片段:
void fizz_buzz(int range) {
//Notice that we don't need to check for divisibility by both values now
int i = 0;
for(i = 1; i < range; ++i) {
string str;
if(i % 3 == 0)
str += "Fizz";
if(i % 5 == 0)
str += "Buzz";
if(str.empty())
str += to_string(i);
cout << str << " ";
}
}
Run Code Online (Sandbox Code Playgroud)
但是,面试官再次表示他对这种方法也不满意。那么,接近 Fizz Buzz 的理想方式应该是什么?
我认为您不需要整个字符串来检查是否打印了任何内容,单个字符串bool就可以了。除此之外,我会将数字收集在一个数组中以便于扩展。除此之外,你的第二个解决方案似乎还不错。这是我的做法:
#include <cstdio>
#include <utility>
void fizzbuzz(int const range) noexcept {
constexpr std::pair<int, char const*> pairs[] {
{3, "Fizz"}, {5, "Buzz"}, {7, "Fuzz"}, {13, "Bizz"}
};
for (int i = 1; i < range; ++i) {
bool none = true;
for (auto const& [num, str] : pairs) {
if (i % num == 0) {
std::printf("%s", str);
none = false;
}
}
if (none) {
std::printf("%d", i);
}
std::putchar('\n');
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
314 次 |
| 最近记录: |