国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設(shè)計 > 正文

歐拉計劃 66

2019-11-10 18:43:00
字體:
供稿:網(wǎng)友

考慮如下形式的二次丟番圖方程:

x**2 – D*y**2 = 1

例如當 D=13時, x 的最小解是 649**2 – 13×180**2 = 1.

可以認為當D是平方數(shù)時方程無正整數(shù)解。

通過尋找當D = {2, 3, 5, 6, 7}時 x 的最小解,我們得到: 3**2 – 2×2**2 = 1 2**2 – 3×1**2 = 1 9**2 – 5×4**2 = 1 5**2 – 6×2**2 = 1 8**2 – 7×3**2 = 1

因此對于D ≤ 7, x 的最小解的最大值在D=5時取到。

找出D ≤ 1000中使得 x 的最小值取到最大的D的值。

參考:http://www.mathblog.dk/PRoject-euler-66-diophantine-equation/

x_max = 0D_res = 0for D in range(2, 1001): limit = int(pow(D, 0.5)) if limit * limit == D: continue m = 0 d = 1 a = limit numm1 = 1 num = a denm1 = 0 den = 1 while (num ** 2 - D * den ** 2 != 1): m = d * a - m d = (D - m * m) // d a = (limit + m) // d numm2 = numm1 numm1 = num denm2 = denm1 denm1 = den num = a * numm1 + numm2 den = a * denm1 + denm2 if num > x_max: x_max = num D_res = Dprint(D_res)
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鹤岗市| 黄浦区| 大名县| 杭锦旗| 蓬莱市| 山东省| 九龙城区| 贵定县| 龙门县| 五原县| 沅江市| 盐池县| 肥西县| 宜州市| 仁怀市| 武山县| 阳高县| 宁德市| 清苑县| 喀喇| 师宗县| 永城市| 武强县| 富源县| 成安县| 武鸣县| 朝阳区| 云浮市| 高陵县| 巴林右旗| 巴塘县| 北碚区| 贞丰县| 英吉沙县| 济南市| 墨玉县| 北京市| 万安县| 安西县| 夹江县| 青川县|