树缝里也漏着一两点路灯光,没精打彩的,是渴睡人的眼。春尚浅,几处山顶上的梅花却挣扎着吐出红苞来。微风柔和地吹,柔和地爱抚我的面孔。荷塘里的荷花都羞涩地打着朵。落叶随着风高低起舞。
老师布置作业给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 />");
}
结果还是同第一次的结果一样。
本文asp.net中显示1至20相同数字相乘的结果,若值比50小就不显示到此结束。十年后所有难过都是下酒菜。小编再次感谢大家对我们的支持!