【发布时间】:2009-11-22 00:31:44
【问题描述】:
问题:
给定以下代码sn-p:
bool foo(int n) {
for(int i=3;i<sqrt(n)+0.5;i+=2)
{
if((n%i)==0){
return false;
}
}
return true;
}
你能弄清楚函数 foo 的用途是什么吗?
嗯,乍一看,似乎 foo 正在检查素数,但事实并非如此。我编写了一个小测试程序并得到了以下输出:
对于 1 到 100 之间的这些数字,foo 返回 true:
1 2 3 4 5 6 7 8 10 11 13 14 16 17 19 20 22 23 26 28 29 31 32 34 37 38 41 43 44 4 6 47 52 53 58 59 61 62 64 67 68 71 73 74 76 79 82 83 86 88 89 92 94 97
对于 1 到 100 之间的这些数字,foo 返回 false:
9 12 15 18 21 24 25 27 30 33 35 36 39 40 42 45 48 49 50 51 54 55 56 57 60 63 65 66 69 70 72 75 77 78 80 81 84 85 87 90 91 93 95 96 98 99 100
我无法理解 foo 在该系列中正在做什么。
【问题讨论】:
-
@nthrgeek:为什么这个函数叫 foo?你有没有机会通过反汇编程序获得这个功能,这就是为什么你不知道它的名字?给我们一些背景信息,否则我倾向于相信你在逆向工程你不应该的东西!
-
@jkp: 不是,是面试题,要我们回答这个函数的目的,所以取名foo。 :)