軟體工程第三周作業(二)

來源:互聯網
上載者:User

標籤:

程式碼:

using System;using System.Collections.Generic;using System.Text;namespace FindTheNumber{  class Program  {    static void Main(string[] args)    {      int [] rg =          {2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,           20,21,22,23,24,25,26,27,28,29,30,31};      for (Int64 i = 1; i < Int64.MaxValue; i++)      {        int hit = 0;        int hit1 = -1;        int hit2 = -1;        for (int j = 0; (j < rg.Length) && (hit <=2) ; j++)        {          if ((i % rg[j]) != 0)          {            hit++;            if (hit == 1)            {              hit1 = j;            }            else if (hit == 2)            {              hit2 = j;            }            else              break;          }        }        if ((hit == 2)&& (hit1+1==hit2))        {          Console.WriteLine("found {0}", i);        }      }    }  }}

1.   這個程式找的是在rg數組中只有連續的兩個數不能整除,其餘都能整除的符合這樣條件的數。

2.   存在;最小為數組中的數除16和17外的最小公倍數2123581660200 .

3.   外迴圈執行了2123581660200次,執行一次外迴圈內迴圈執行大約12次,參考電腦配置,執行一次%用80個周期,所以執行時間約為:2123581660200*12*80/(4*10^9*60)=8500min 。

4.   同時對n個i進行操作,大大提高程式執行速度。

註:一開始認為不能被整除的只有連續的兩個質數2,3但如果這樣這個數就不會存在。經過與同學的交流得到思路。連續的兩個數只能是16和17。(程式執行時間參考了薛鵬飛的部落格)

軟體工程第三周作業(二)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.