最好的解决方案是什么?(任何语言)



这里有一个问题。有人能找出答案吗?

最多允许两次"if"测试!

Given numbers from 1 to 100
If this number is divisble by 21 print "foobar"
If this number is divisble by 7 print "bar"
If this number is divisble by 3 print "foo"
If none of the above, print the number

只能打印一个数字。例如,数字21应该只打印"foobar",而不是全部打印"foobar"、"bar"、"foo"。

可以用任何语言完成。

非常感谢。

诀窍是,实现问题中的4个如果,我们可以根据中间的2推断出顶部和底部。

for(int i=1;i<=100;i++)
{
    string numberstr = i.ToString();
    if(i % 3 == 0)
    {
        Console.Write("foo");
        numberstr = "";
    }
    if(i % 7 == 0)
    {
        Console.Write("bar");
        numberstr = "";
    }
    Console.WriteLine(numberstr);
}

Ohai,FizzBuzz。

#include <iostream>
int main(){
  for(int i=1; i <= 100; ++i){
    bool foo = !(i % 3), bar = !(i % 7);
    bool num = !(foo || bar);
    foo && std::cout << "foo";
    bar && std::cout << "bar";
    num && std::cout << i;
    std::cout << "n";
  }
}

Ideone上的实例。

如果使用linq,则为零(但实际上是通过使用条件运算符作弊)。

using System;
using System.Linq;
namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            var lines = from i in Enumerable.Range(1, 100)
                        let foopart = i % 3 == 0 ? "foo" : ""
                        let barpart = i % 7 == 0 ? "bar" : ""
                        let numberpart = i % 3 != 0 && i % 7 != 0 ? i.ToString() : ""
                        select foopart + barpart + numberpart;
            foreach (var line in lines)
                Console.WriteLine();
        }
    }
}

我可以使用if语句来完成此操作:

array[1..100] = {"1", "2", "foo", "4", "5", "6", "bar", ... "bar", "foo", "100"}
for i = 1 to 100:
    print array[i]

我将由您填写...位并将其转换为真正的语言。我会自己做,但我怀疑这样一项任务的有用性:-)

或者,也许更好:

print "1n2nfoon4n...97nbarnfoon100"

当然,有3个条件,但没有IF:)C#

var list = Enumerable.Range(1, 100).Select(n =>
            n % 21 == 0 ? "foobar" :
            n % 7 == 0 ? "bar" :
            n % 3 == 0 ? "foo" : n.ToString());
foreach(var n in list)
{
    Console.WriteLine(n);
}

C 中的代码

char* x = "n"; 
int i;
for(i=1;i<=75;i++)
{   
    int y = ((i%5 == 0) && printf("%s","Foo")); 
    y=y+((i%7 == 0) && printf("%s","Bar"));
    ((!y==1) && printf("%d",i));
    printf("%s",x);
}

将结果保存在字符串中。

示例:

字符串str=number.toString();

if(number % 7 == 0) {
   str = "FOO";
}
if(number % 5 == 0) {
   str = i % 7 == 0 ? str + "BAR" : "BAR";
}
return str;
pseudcode:
if (num/3)
{
    print foo
}
elseif (num/7)
{
    print bar
}
else
{
        print num
}

基本上,当遇到可被21整除的数字时,foobar会被连接起来。

for (int i = 100; i > 0; i--) {
        int mul3  = (i /3)*3;
        int mul7 = (i /7) * 7;
        String fooOrBar = (mul3 == i && mul7 == i) ? "foobar" :(mul3 == i) ? "foo" : (mul7 == i) ? "bar" : "";
        System.out.println(fooOrBar);
    }

相关内容

最新更新