老師布置作業給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 />");
}
結果還是同第一次的結果一樣。