老师布置作业给Insus.NET做,题目如标题。
感兴趣的网友也可以练习练习。现在Insus.NET的作答如下,但老师还没有看,因此答案是否正确或是最好的,还不能确定,只是供参考。
第一次以最快的方法来实现:
复制代码代码如下:
for (int i = 1; i <= 20; i++)
{
int j = i * i;
if (j >= 50)
Response.Write(i + " × " + i + " = " + j + "<br />");
}
得到结果如下:
在上面完成之后,Insus.NET马上想起,老师一定不会出这样简单的问题的。会不会老师要Insus.NET实现,积小于50的两个数字相乘的不必循环呢,减轻性能,因此马上修改刚才完成的程序:
首先求出50的平方根数为多少,得到的数为Double的数据类型,也就是说有可以是小数出现,把它转换为Integer:
复制代码代码如下:
int min = (int)Math.Sqrt(50);
这样,我们就可以知道是从哪一个Integer开始进行循环。但是某一天,不再是计算积为50,而是改为积64的话,它的平方根为8。如果以8的平方刚好是64,而题目是要大于64的,因此正确是从9开始。故还是下面的判断:
复制代码代码如下:
if (Math.Pow(min, 2) < 50)
min += 1;
最终Insus.NET的答案如下:
复制代码代码如下:
for (int i = min; i <= 20; i++)
{
int j = i * i;
Response.Write(i + " × " + i + " = " + j + "<br />");
}
结果还是同第一次的结果一样。