Compute the Maximum Integer Right Triangles Solutions
- 时间:2020-09-10 12:45:51
- 分类:网络文摘
- 阅读:143 次
If p is the perimeter of a right angle triangle with integral length sides, {a,b,c}, there are exactly three solutions for p = 120.
{20,48,52}, {24,45,51}, {30,40,50}
For which value of p ≤ 1000, is the number of solutions maximised?
Maximum Integer Right Triangles Solutions
We can assume bruteforce the shorter side i from 1 to 1000. Then, we can bruteforce the the other side (of the right angle) from i to 1000 – i. The slope k can be computed via Sqrt(i*i+j*j). If three sides sum less or equal to 1000, then we increment the counter for the perimeter.
In the following Javascript, we use a dictionary (or hash map) to store the key-value pairs where key is the perimeter and the value is the number of the solutions when corresponding perimeter is chosen.
And at the end, we have to go through the dictionary to find out the key where the maximum value is stored.
1 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 | let count = { }; for (let i = 1; i <= 1000; ++ i) { for (let j = i; i + j <= 1000; ++ j) { let k = Math.floor(Math.sqrt(j * j + i * i)); if (k * k == i * i + j * j) { let p = i + j + k; if (p <= 1000) { if (typeof count[p] === 'undefined') { count[p] = 1; } else { count[p] ++; } } } } } const keys = Object.keys(count); let cnt = 0; let p = 0; for (let key of keys) { if (count[key] > cnt) { cnt = count[key]; p = key; } } console.log(p); |
let count = {
};
for (let i = 1; i <= 1000; ++ i) {
for (let j = i; i + j <= 1000; ++ j) {
let k = Math.floor(Math.sqrt(j * j + i * i));
if (k * k == i * i + j * j) {
let p = i + j + k;
if (p <= 1000) {
if (typeof count[p] === 'undefined') {
count[p] = 1;
} else {
count[p] ++;
}
}
}
}
}
const keys = Object.keys(count);
let cnt = 0;
let p = 0;
for (let key of keys) {
if (count[key] > cnt) {
cnt = count[key];
p = key;
}
}
console.log(p);–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:4个与大豆营养价值有关的真假说法 早餐第一口吃什么样的食物最养胃 萝卜颜色各异 营养价值各不相同 冬季养生美味 各种萝卜汤养胃又暖身 电脑族抗辐射可以经常吃这种水果 生活中常见的保护肠道健康的食物 注意三个饮食原则让你远离癌症威胁 羊奶粉调查:10款羊奶粉中有7款掺牛乳 冬季吃火锅大有门道 火锅底料很重要 寒冷天气吃多了这5类食物会伤及肠胃
- 评论列表
-
- 添加评论